uzumeti
@uzumeti

Почему Javascript срабатывает на второй клик, а на первый не срабатывает?

Есть простенький код:

const btn = document.querySelector(".menu88");
const content = document.querySelector(".submenu");
btn.addEventListener("click", btnClick);
function btnClick() 


{
	let x = document.getElementsByClassName('submenu')[0];
      if (x.style.display == "none"){
	  x.style.display = "block";
	  } else {
	 x.style.display = "none"}
    };


Он должен открывать и закрывать выпадающее подменю в wordpress. Пока я делаю это в редакторе кода - всё работает. Когда переношу на сайт - срабатывает только по второму клику. Первый клик ничего (в моем случае меняет цвет строчки с пунктом). Второй клик - выпадает подменю. Третий клик - подменю скрывается. Четвертый клик - опять выпадает. Нужно, чтобы сразу после загрузки странички подменю выпадало по клику при первом нажатии.

Догадываюсь, что проблема появляется из-за того, что первый клик запускает сам обработчик или что-то такое и переписывает какой-то пустой стиль. Но не соображу как это исправить)
  • Вопрос задан
  • 165 просмотров
Решения вопроса 1
MrDecoy
@MrDecoy Куратор тега JavaScript
Верставший фронтендер
Ванга клуб на этой неделе объявляю открытым.

Потому что по умолчанию в разметке(которую Вы решили любезно нам не предоставлять) у Вас у .submenu нет инлайн стилей, а скрыт он через css. Поэтому на первый клик он задаёт style.display = none, из-за того что x.style.display === "" а не 'none' то есть идёт по ветке else, а потом уже работает как "предполагалось".

Если зададите инлайн стиль style="display: none", то будет работать с первого раза.
То есть в разметке сразу должно быть<element style="display: none">

Ну а лучше отказаться от diplay: none и использовать атрибут hidden или скрывать\показывать через css классы.
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

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