Búsquedas recientes
No hay búsquedas recientes
data:image/s3,"s3://crabby-images/e78da/e78da44cf9d41e5192d1a3be0dd764bf80d93320" alt="Krisztian Gyuris's Avatar"
Krisztian Gyuris
Incorporación 10 jul 2024
·
Última actividad 10 jul 2024
Seguimientos
1
Seguidores
0
Actividad total
3
Voto
1
Suscripción
1
RESUMEN DE LA ACTIVIDAD
INSIGNIAS
ARTÍCULOS
PUBLICACIONES
COMENTARIOS DE LA COMUNIDAD
COMENTARIOS DE ARTÍCULOS
RESUMEN DE LA ACTIVIDAD
Última actividad de Krisztian Gyuris
Krisztian Gyuris hizo un comentario,
Yes, it is possible. Here is the modified code that closes the currently open accordion automatically once a new one is clicked:
var acc = document.getElementsByClassName("accordion");
var i;
for (i = 0; i < acc.length; i++) {
acc[i].addEventListener("click", function() {
let activeAccordions = document.querySelectorAll(".accordion-div .accordion.active");
for (let j = 0; j < activeAccordions.length; j++) {
activeAccordions[j].classList.remove("active");
activeAccordions[j].nextElementSibling.style.maxHeight = null;
}
var panel = this.nextElementSibling;
if (!this.classList.contains("active")) {
this.classList.add("active");
panel.style.maxHeight = panel.scrollHeight + "px";
} else {
this.classList.remove("active");
panel.style.maxHeight = null;
}
});
}
So when the accordion is clicked, I try first to find all currently active accordions, remove the active class, and reset the maxHeight of the panel. Then check the current panel to see if it is active and if not, the active class is added, and changing the maxHeight to scrollHeight.
I also created a sandbox to demo the component:
https://codesandbox.io/p/sandbox/friendly-julien-tvc882
Ver comentario · Publicado 10 jul 2024 · Krisztian Gyuris
0
Seguidores
0
Votos
0
Comentarios