[英]How can I add or remove class using querySelectorAll() in react functional component
I am trying to add or remove an active class if I click any list item but the code is not working.如果我单击任何列表项但代码不起作用,我将尝试添加或删除活动的 class。 Here is my function
这是我的 function
const list = document.querySelectorAll('.m-list') as NodeListOf<Element>
function activeLink(this: any) {
list.forEach((item) => item.classList.remove('active'))
// list.forEach((item) => item.classList.add('active'))
this.classList.add('active')
}
list.forEach(item => item.addEventListener('click', activeLink))
Full code with HTML完整代码 HTML
export default function MobileNavigation() {
const list = document.querySelectorAll('.m-list') as NodeListOf<Element>
function activeLink(this: any) {
list.forEach((item) => item.classList.remove('active'))
// list.forEach((item) => item.classList.add('active'))
this.classList.add('active')
}
list.forEach(item => item.addEventListener('click', activeLink))
return <div className='mobile-navigation'>
<ul>
<li className='m-list active'>
<a href="#">
<span className='m-icon'><i className="fa-solid fa-house"></i></span>
<span className='m-text'>Home</span>
</a>
</li>
<li className='m-list'>
<a href="#">
<span className='m-icon'><i className="fa-solid fa-shop"></i></span>
<span className='m-text'>Shop</span></a>
</li>
<li className='m-list'>
<a href="#"><span className='m-icon'><i className="fa-solid fa-store"></i></span>
<span className='m-text'>Vendors</span></a>
</li>
<li className='m-list'>
<a href="#"><span className='m-icon'><i className="fa-solid fa-address-card"></i></span>
<span className='m-text'>About us</span></a>
</li>
<li className='m-list'>
<a href="#"><span className='m-icon'><i className="fa-solid fa-headset"></i></span>
<span className='m-text'>Contact Us</span></a>
</li>
<div className="indicator"></div>
</ul>
</div>;
}
const list = document.querySelectorAll('.m-list') as NodeListOf<Element>
function activeLink(e:any) {
list.forEach((item) => item.classList.remove('active'))
// list.forEach((item) => item.classList.add('active'))
e.classList.add('active')
}
list.forEach(item => item.addEventListener('click', (e)=>activeLink(item)))
Just replace this with your code... it will start working now.只需用您的代码替换它……它现在就会开始工作。 I hope this helped you solve your issue:)
我希望这可以帮助您解决问题:)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.