• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Javascript menu usunięcie klasy

Object Storage Arubacloud
0 głosów
234 wizyt
pytanie zadane 4 listopada 2018 w JavaScript przez Pawel82 Użytkownik (740 p.)
edycja 4 listopada 2018 przez Pawel82

Witam mam kod który pokazuje menu responsywne, chciałbym żeby po kliknięciu w dowolną pozycję menu, menu zostało ukryte. Wiem że trzeba usunąć klasę is-active.

  var burger = document.querySelector('.navbar-burger');
  var menu = document.querySelector('.navbar-menu');
  if (burger !== null) {
  burger.addEventListener('click', function() {
  burger.classList.toggle('is-active');
  menu.classList.toggle('is-active');

  });
 }
 <nav class="navbar" role="navigation" aria-label="navigation">
      <div class="navbar-brand">
        <a href="home" class="navbar-item">Logo</a>
        <a role="button" class="navbar-burger" aria-label="menu" aria-expanded="false" data-target="menu">
          <span aria-hidden="true"></span>
          <span aria-hidden="true"></span>
          <span aria-hidden="true"></span>
        </a>
      </div>
      <div id="menu" class="navbar-menu">
        <div class="navbar-end">
          <a href="#" class="navbar-item">Home</a>
          <a href="#" class="navbar-item">O mnie</a>
          <a href="#" class="navbar-item">Zdjęcia</a>
          <div class="navbar-item has-dropdown dropdown">
            <a href="#" class="navbar-link">Dropdown</a>
            <div class="navbar-dropdown">
              <a href="#" class="navbar-item">Drop 1</a>
              <a href="#" class="navbar-item">Drop 2</a>
              <a href="#" class="navbar-item">Drop 3</a>
            </div>
          </div>
          <a href="#" class="navbar-item">Kontakt</a>
        </div>
      </div>

    </nav>

 

1 odpowiedź

0 głosów
odpowiedź 4 listopada 2018 przez arces Pasjonat (17,700 p.)

Musisz dodać na każdy element menu (link) addEventListener na 'click', który będzie usuwał klasę z menu i tyle. Jeżeli to napisałeś sam, to nie będziesz miał problemu z napisaniem tego co Ci podałem.

Pamiętaj, że w tym przypadku musisz zastosować querySelectorAll dla wszystkich elementów menu oraz później forEach natych elementach, a dopiero później addEventListener.

 

Powinno to wyglądać mniej więcej tak:

var links = document.querySelectorAll(element wskazujący na linki);
links.forEach(el => el.addEventListener('click', function () {
menu.classList.remove('is-active');
});

 

komentarz 4 listopada 2018 przez Pawel82 Użytkownik (740 p.)

@Tomek Sochacki,
 aż tak nie znam javascript ale zainteresował mnie wątek o event delegation. Tylko mnie wiem jak się za to zabrać

komentarz 4 listopada 2018 przez Pawel82 Użytkownik (740 p.)

@arces,
 niestety nie

komentarz 4 listopada 2018 przez arces Pasjonat (17,700 p.)

@Tomek Sochacki, pokażesz jak to zrobić w tym przypadku?

1
komentarz 4 listopada 2018 przez Tomek Sochacki Ekspert (227,510 p.)
https://codepen.io/anon/pen/QJwyvx?editors=1011

Tu masz prosty przykład. Tworzymy listę ul, w niej różne elementy li i nasłuchiwanie na click ustawiamy tylko dla całej listy. Następnie wewnątrz callbacka sprawdzamy, czy kliknięty został element li i tylko wtedy rzucamy logiem w konsoli - poklikaj sobie w elementy.
komentarz 4 listopada 2018 przez Pawel82 Użytkownik (740 p.)
Przykład ok. tylko w tym przypadku nie ma listy. Jak mam poprawić swój kod

Podobne pytania

–1 głos
1 odpowiedź 176 wizyt
+1 głos
1 odpowiedź 348 wizyt
pytanie zadane 12 lipca 2021 w JavaScript przez xjafajx Użytkownik (740 p.)
0 głosów
2 odpowiedzi 2,717 wizyt
pytanie zadane 31 sierpnia 2016 w JavaScript przez Q_Nick Mądrala (5,010 p.)

92,579 zapytań

141,432 odpowiedzi

319,664 komentarzy

61,964 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...