Задать вопрос
@Speakermen

Почему Uncaught ReferenceError: dropdown is not defined at HTMLLIElement.onclick?

Не могу понять почему в анонимную функцию не попадает event?



<li class="rounded" onclick="App.create(event)">

const App = (() => {
  document.getElementById("switch-thema").addEventListener("change", () => {
    const thema = document.getElementById("thema");
    if (
      thema.className == "w-64 h-screen bg-white rounded relative theme-white"
    ) {
      thema.className = "w-64 h-screen bg-black rounded relative theme-black";
    } else if (
      thema.className == "w-64 h-screen bg-black rounded relative theme-black"
    ) {
      thema.className = "w-64 h-screen bg-white rounded relative theme-white";
    }
  });

  document.getElementById("toggle").addEventListener("click", () => {
    const noactive = document.getElementById("noactive");

    if (noactive.className == "flex flex-row gap-6 toggle-noactive") {
      noactive.className = "flex flex-row gap-6 toggle-active";
      console.log((toggle.lastElementChild.className = "uil uil-angle-right"));
    } else if (noactive.className == "flex flex-row gap-6 toggle-active") {
      noactive.className = "flex flex-row gap-6 toggle-noactive";
      console.log((toggle.lastElementChild.className = "uil uil-angle-left"));
    }
  });

  return {
    create: function dropdown(event) {
      if (event.target.parentElement.className == "dropdown rounded") {
        event.target.parentElement.className = "rounded";
        event.target.parentElement.firstElementChild.className =
          "uil uil-angle-right -mx-2 pl-3";
        event.target.nextElementSibling.className =
          "dropdown-menu bg-color hidden";
      } else if (
        event.target.parentElement.className == "rounded" &&
        event.target.localName == "a"
      ) {
        event.target.parentElement.className = "dropdown rounded";
        event.target.parentElement.firstElementChild.className =
          "uil uil-angle-down -mx-2 pl-3";
        event.target.nextElementSibling.className = "dropdown-menu bg-color";
      }
    },
  };
})();
  • Вопрос задан
  • 64 просмотра
Подписаться 1 Простой Комментировать
Решения вопроса 1
delphinpro
@delphinpro Куратор тега JavaScript
frontend developer
Причем здесь передача event?
В ошибке прямым текстом написано: Я не знаю ни про какую функцию dropdown
Если хотите использовать ее в html, то функцию следует объявлять в глобальном контексте.
Например так
window.dropdown = function(event) {
}
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

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