aGreatCook
aGreatCook

Reputation: 21

How do I toggle multiple list elements with same class?

I have a list with 5 elements of the same class: "navbar_item". With this code I toggle the 'active' status when clicking the item with the class mentioned, but it only toggles the first element of the list. What do I do to toggle all of them?

const menu = document.querySelector('#mobile-menu');
const menuMenu = document.querySelector('.navbar_menu');
const menuItem = document.querySelector('.navbar_item');

const mobileMenu = () => {
    menu.classList.toggle('is-active');
    menuMenu.classList.toggle('active');
    menuItem.classList.toggle('active');
};

menu.addEventListener('click', mobileMenu);
menuItem.addEventListener('click', mobileMenu);

Upvotes: 2

Views: 894

Answers (2)

bin liu
bin liu

Reputation: 227

because "querySelector" will only get the first element, if you want to get All; please use "querySelectorAll"; you can also to learn Event delegation to get a better way to solove this problem

const menu = document.querySelector('#mobile-menu');
const menuMenu = document.querySelector('.navbar_menu');
const menuItems = document.querySelectorAll('.navbar_item');

const mobileMenu = () => {
    menu.classList.toggle('is-active');
    menuMenu.classList.toggle('active');
};

menu.addEventListener('click', mobileMenu);
for(let i = 0; i < menuItems.length; i ++) {
  menuItems[i].addEventListener('click', () => {
    menuItem[i].classList.toggle('active');
  });
}

Upvotes: 0

ahsan
ahsan

Reputation: 1504

You need to use querySelectorAll to get all elements. This provides a list which you can iterate or loop through to both apply eventListeners and toggle classes.

Something like this

const menuItem = document.querySelectorAll('.navbar_item');

const mobileMenu = () => {
    menuItem.forEach( (item) => {
        item.classList.toggle('active');
  })       
};

menuItem.forEach( (item)=> {
    item.addEventListener('click', mobileMenu)
})
.active{
  background-color: lightblue;
}

.navbar_item{
  margin-bottom: 10px;
}
<div class="navbar_menu">
  <div class="navbar_item">Item 1</div>
  <div class="navbar_item">Item 2</div>
  <div class="navbar_item">Item 3</div>
  <div class="navbar_item">Item 4</div>
  <div class="navbar_item">Item 5</div>
</div>

Upvotes: 1

Related Questions