1.Uncaught Invariant Violation: Too many re-renders. React limits the number of renders to preven...

1.Uncaught Invariant Violation: Too many re-renders. React limits the number of renders to prevent an infinite loop。
原因是在為事件傳遞函數(shù)時(shí)直接寫(xiě)了setState導(dǎo)致報(bào)錯(cuò)。原因是調(diào)用setCount,React會(huì)重新調(diào)用render方法來(lái)重新渲染UI。再次渲染函數(shù)組件App時(shí)導(dǎo)致陷入死循環(huán)。

解決辦法:如果放在return體內(nèi)就不會(huì)出現(xiàn)這種情況了

export default function App() {
    const [count, setCount] = useState(0)
    return (
        <div>
            <h2>當(dāng)前數(shù)值:{count}</h2>
            //<button onClick={setCount(count+1)}>+1</button>
            //<button onClick={setCount(count-1)}>-1</button>
            <button onClick={()=>{setCount(count+1)}}>+1</button>
            <button onClick={()=>{setCount(count-1)}}>-1</button>
        </div>
    )
}

至于為什么后者在點(diǎn)擊之后才會(huì)執(zhí)行原因如下

onClick={這里是一個(gè)匿名函數(shù)或者函數(shù)引用}因此:
onClick={this.handleClick(i)}這里包裹的函數(shù)其實(shí)是一個(gè)自執(zhí)行函數(shù),當(dāng)解析器執(zhí)行到這里的時(shí)候,handleClick函數(shù)會(huì)立即執(zhí)行,并不需要點(diǎn)擊才能觸發(fā)。
onClick={() => this.handleClick(i)},onClick={this.handleClick}這兩個(gè)函數(shù)都不是自執(zhí)行函數(shù),所以會(huì)在點(diǎn)擊的時(shí)候才觸發(fā)。這兩者的區(qū)別又在于,點(diǎn)擊時(shí),前者會(huì)執(zhí)行一個(gè)匿名函數(shù)(箭頭函數(shù)),在這個(gè)函數(shù)里調(diào)用傳參函數(shù)(this.handleClick(i)),后者直接調(diào)用了this.handleClick,因此this.handleClick(i),this.handleClick都是函數(shù)引用。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容