@Smirator

Как написать нормальной функцией?

Приветствую всех. Есть код аккордеона. На данный момент работает получая элементы по id. Но, это не верный подход, т.к. увеличивается количество элементов и код превращается в летопись.
Подскажите, пожалуйста, как можно преобразовать в адекватный скрипт?
document.getElementById('panel-one').onclick = function() {
  document.getElementById('panel-one').classList.toggle('active');
  if(document.getElementById('panel-one').classList.contains('active')){
    document.getElementById('panel-one').classList.add('changing-icon');
  } else {
    document.getElementById('panel-one').classList.remove('changing-icon');
  }
}

document.getElementById('panel-two').onclick = function() {
  document.getElementById('panel-two').classList.toggle('active');
  if(document.getElementById('panel-two').classList.contains('active')){
    document.getElementById('panel-two').classList.add('changing-icon');
  } else {
    document.getElementById('panel-two').classList.remove('changing-icon');
  }
}
  • Вопрос задан
  • 86 просмотров
Решения вопроса 1
dedalik
@dedalik
Веб разработчик
Привет, да с id это не правильно, так как можно забыть и про дублировать одинаковые id. Можно попробовать через loop, что-то вроде этого:

const panels = document.getElementsByClassName("panel");
const i;

for (i = 0; i < panels.length; i++) {
  panels[i].addEventListener("click", function() {
   // тут ещё можно поставить удаление у всех акордионов класса 'active', если необходимо
    this.classList.toggle("active");
    const panel = this.nextElementSibling;
    if(this.classList.contains('active')){
         this.classList.add('changing-icon');
    } else {
       this.classList.remove('changing-icon');
    }
   if (panel.style.maxHeight) {
      panel.style.maxHeight = null;
    } else {
      panel.style.maxHeight = panel.scrollHeight + "px";
    }
  });
}


<button class="panel">Аккордеон 1</button>
<div class="panel-body">
  <p>текст аккордеона</p>
</div>
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
Rsa97
@Rsa97
Для правильного вопроса надо знать половину ответа
Меняете все id на общий класс panel и используете всплытие событий. Вместо документа можно повесить обработчик на любого общего родителя.
document.addEventListener(
  'click', 
  (e) => {
    // const classes = e.target.classList;
    const classes = e.target.closest('.panel')?.classList;
    if (!classes?.contains('panel')) {
      return;
    }
    classes.toggle('active');
    classes.toggle('changing-icon', classes.contains('active'));
  }
);
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы