la mejor opción es la que posteo
InKarC aunque yo le mandaria el indice de la pestaña y con eso lanzaria un click
pasa que primero deberias optimizar tu html y tu js
por ejemplo el html podrias hacerlo asi de simple
Código HTML:
Ver original
<h1 class="titulo">TRATAMIENTOS ODONTOLOGICOS
</h1>
<div class="accordionContent"> El contenido del implantes
<div class="accordionContent"> El contenido del Blanqueamiento
<div class="accordionContent"> El contenido del Ortodoncia
y el jquery fijate que actualmente como lo tienes estas agregando lineas por cada item que agregas, con la estructura html que te propongo solo necesitas saber manejarte por ella
el jquery:
Código Javascript
:
Ver original$( function(){
//algo.com/archivo.html?clave ('clave' debe ser un numero)
var indice = String(window.location).split('?')[1];
//Oculto todos los contenidos del acordeon
$('.accordionContent').hide();
//Le doy un evento a cada h2 que son los titulos de cada tratamiento
$('#accordion>h2').click(function() {
//Si activo esta definido quiere decir que hay un contenido abierto, entonces lo cierro
if ( typeof activo != 'undefined' )
activo.slideUp();
//Guardo en activo el div accordionContent y a continuacion lo abro
activo = $(this).next();
activo.slideDown('normal');
});
//Lanzo un click en la pestaña segun el indice que obtengo de la url
$('#accordion>h2:eq('+indice+')').click();
});
fijate que el evento click le doy a los h2, el contenido de ese item va a ser el div que le sigue, para acceder a él uso el next(), lo guardo en una variable para saber en el proximo click que debo ocultarlo
para entrar a esa seccion y que esté activa el item que quieres visualizar desde el link que presionaste en una página externa obtengo la bandera como lo propuso InKarC pero envio el índice
cada h2 tiene el evento clic entonces el primer h2 tiene índice 0, el segundo va a ser 1 asi sucesivamente
encontes extraigo el indice pasado por url y la guardo en una variable 'indice'
al final del script lo único que hago es seleccionar el h2 con dicho índice y lanzo el clic, entonces se abre esa sección
te paso todo completo para que lo pruebes
pagina externa con links de ejemplos
Código HTML:
Ver original<a href="urlAcordeon.html?0">Implantes
</a> <a href="urlAcordeon.html?1">Blanqueamiento
</a> <a href="urlAcordeon.html?2">Ortodoncia
</a>
modifica la url por el nombre del archivo que contiene el acordeón
y prestá atención como se relaciona la url con los bloques del acordeón
url del link Implantes es urlAcordeon.html?0
el indice (posición) del h2 del bloque de la sección de Implantes en el acordeón es 0 (los índices comienzan en 0)
para Blanqueamiento va a ser 1
para Ortodoncia va a ser 2
al obtener ese indice pasado por la url utilizo eso para lanzar un click en el h2 con ese indice
pagina que contiene el acordeón
Código HTML:
Ver original <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.5/jquery.min.js"></script>
$( function(){
//algo.com/archivo.html?clave ('clave' debe ser un numero)
var indice = String(window.location).split('?')[1];
//Oculto todos los contenidos del acordeon
$('.accordionContent').hide();
//Le doy un evento a cada h2 que son los titulos de cada tratamiento
$('#accordion>h2').click(function() {
//Si activo esta definido quiere decir que hay un contenido abierto, entonces lo cierro
if ( typeof activo != 'undefined' )
activo.slideUp();
//Guardo en activo el div accordionContent y a continuacion lo abro
activo = $(this).next();
activo.slideDown('normal');
});
//Lanzo un click en la pestaña segun el indice que obtengo de la url
$('#accordion>h2:eq('+indice+')').click();
});
#contenedor{width:300px}
.titulo{font-size:16px; background:#777777; color:#fff}
h2{font-size:14px; background:#bbbbbb; margin:0}
.accordionContent{background:#dddddd;}
<h1 class="titulo">TRATAMIENTOS ODONTOLOGICOS
</h1>
<div class="accordionContent"> El contenido del implantes
<div class="accordionContent"> El contenido del Blanqueamiento
<div class="accordionContent"> El contenido del Ortodoncia
y por mas que agregues secciones al acordeón no vas a necesitar agregar cosas al jquery
espero que se entienda :P