亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

React - 加載頁面一次調用所有 onClicks,然后單擊按鈕不執行任何操作

React - 加載頁面一次調用所有 onClicks,然后單擊按鈕不執行任何操作

慕仙森 2023-09-04 15:41:05
我對 React 還很陌生,我對 HTML 和 CSS/SASS 有很好的理解,所以到目前為止我還沒有遇到任何問題。我想根據用戶當時所在的頁面突出顯示導航欄上的一個按鈕。我嘗試向將調用函數的按鈕添加一個簡單的onClick,傳遞一個字符串告訴它剛剛單擊了“ home ”或“ contact ”。我在函數中添加了一個alert(),這樣我就可以看到按鈕被按下并且方法被調用;但是,當頁面加載時,它會調用每個按鈕方法并為每個按鈕發出警報,然后繼續照常加載,單擊按鈕似乎就好像我從未添加過 onClick 一樣。誰能告訴我這個簡單的功能哪里出了問題?過去5個小時我一直在拔頭發。謝謝你!導航欄.js:function NavBar() {const isActive = "home";return (      <nav className="landing-page__nav-bar nav-bar">  <ul className="nav-bar__list">    <Link to ='/home'><li><a data-page="home" className="home-link">      <button href="landingpage" className={` ${isActive === "home" ? 'btn__nav-bar-btn active-link' : 'btn__nav-bar-btn'}`} onClick={buttonWasClicked("home")}>Home</button>      </a></li>    </Link>    <Link to ='/portfolio'><li><a data-page="portfolio" className="portfolio-link">      <button className={` ${isActive === "portfolio" ? 'btn__nav-bar-btn active-link' : 'btn__nav-bar-btn'}`} onClick={buttonWasClicked("portfolio")}>Portfolio</button>      </a></li>      </Link>    <Link to ='/artwork'><li><a data-page="doodles" className="doodles-link">    <button className={` ${isActive === "artwork" ? 'btn__nav-bar-btn active-link' : 'btn__nav-bar-btn'}`} onClick={buttonWasClicked("artwork")}>Artwork</button>      </a></li></Link>    <Link to ='/photography'><li><a data-page="photography" className="photography-link">      <button className={` ${isActive === "photography" ? 'btn__nav-bar-btn active-link' : 'btn__nav-bar-btn'}`} onClick={buttonWasClicked("photography")}>Photography</button>      </a></li></Link>    <Link to ='/cv'><li><a data-page="cv" className="cv-link">    <button className={` ${isActive === "cv" ? 'btn__nav-bar-btn active-link' : 'btn__nav-bar-btn'}`} onClick={buttonWasClicked("cv")}>CV</button      ></a></li></Link>
查看完整描述

2 回答

?
浮云間

TA貢獻1829條經驗 獲得超4個贊

您在渲染時調用該函數并將該函數的結果傳遞給按鈕的onClick. 相反,您應該提供onClick一個匿名函數,該函數在執行時會使用適當的參數調用您想要的函數。

<button className={` ${isActive === "about" ? 'btn__nav-basr-btn active-link' : 'btn__nav-bar-btn'}`} onClick={() => buttonWasClicked("about")}>About</button>



查看完整回答
反對 回復 2023-09-04
?
幕布斯7119047

TA貢獻1794條經驗 獲得超8個贊

onClick標簽需要一個函數,而不是調用函數。如果您鍵入buttonWasClicked("contact")該函數,則當 DOM 準備就緒時將調用該函數。

相反,你需要寫{() => buttonWasClicked("contact")}


查看完整回答
反對 回復 2023-09-04
  • 2 回答
  • 0 關注
  • 167 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號