簡體   English   中英

如何使用反應功能組件添加或刪除 class

[英]How can I add or remove class using react functional component

我正在使用 React typescript。如果我單擊任何列表項,我會嘗試添加或刪除活動的 class,但代碼有時無法正常工作 所以我想以更好的方式更新我的代碼。 任何人都可以幫助我改進更新我下面的 function 代碼嗎?

這是我要更新的 function

   const list = document.querySelectorAll('.m-list') as NodeListOf<Element>

    function activeLink(e: any) {
        list.forEach((item) => item.classList.remove('active'))
        e.classList.add('active')
    }
    list.forEach(item => item.addEventListener('click', (e) => activeLink(item)))

完整代碼 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>;
}

您的代碼是純 VanillaJS,而不是 Typescript 或 React。 嘗試閱讀有關 Typescript 和 React 的內容,制作示例項目並嘗試 - https://medium.com/codex/typescript-and-create-react-app-11bdebcbf763

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM