I have several dropdown items in my footer. I want to toggle the "active" class list specifically for the clicked element. My code so far is:
I have multiple containers like this:
let dropDowns = document.querySelectorAll('.footer-arrow-container') let dropDownList = document.querySelector('.footer-items-list') dropDowns.forEach((dropDown) => { dropDown.addEventListener('click', () => { dropDownList.closest('ul').classList.toggle('active') }) })
.footer-items-list { display: none; } .active { display: flex; }
<div class="footer-item-container"> <div class="footer-arrow-container"> <!-- dropDowns ; querySelectorAll --> <h2 class="footer-item-title"> Test </h2> <img/> </div> <div class="footer-dropdown-list-container"> <ul class="footer-items-list"> <!-- dropDownList : querySelector --> <li>List item 1</li> <li>List item 2</li> </ul> </div> </div> <div class="footer-item-container"> <div class="footer-arrow-container"> <!-- dropDowns ; querySelectorAll --> <h2 class="footer-item-title"> Test </h2> <img/> </div> <div class="footer-dropdown-list-container"> <ul class="footer-items-list"> <!-- dropDownList : querySelector --> <li>List item 1</li> <li>List item 2</li> </ul> </div> </div>
Currently this just selects "ul" from the first list. It doesn't work with separate other lists, so I've obviously chosen it wrong in JavaScript, and I'm not sure the best way to do this.
P粉5101277412024-02-18 13:16:47
HTML structure is unclear. I take your word for it that every footer item has the same structure and placed two in this example. Basically, the code goes up to the common ancestor and then down to the children.
let dropDowns = document.querySelectorAll('.footer-arrow-container') dropDowns.forEach((dropDown) => { dropDown.addEventListener('click', () => { dropDown.closest('.footer-item-container').querySelector('.footer-items-list').classList.toggle('active') }) })
.footer-items-list { display: none; } .active { display: flex; }