您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“react中的forceupdate怎么用”,內容詳細,步驟清晰,細節處理妥當,希望這篇“react中的forceupdate怎么用”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
在react中,forceupdate()用于強制使組件跳過shouldComponentUpdate(),直接調用render(),可以觸發組件的正常生命周期方法,語法為“component.forceUpdate(callback)”。
本教程操作環境:Windows10系統、react17.0.1版、Dell G3電腦。
僅當組件的狀態或傳遞給它的道具發生變化時,React中的組件才會re-render,但是如果某些數據發生變化,如果我們需要更改組件的re-render,則我們將使用React的forceUpdate()方法。調用forceUpdate()將強制組件re-render,從而跳過該shouldComponentUpdate()方法而調用該組件的render()方法。
提示:通常,避免使用forceUpdate(),而只能從render()中的this.props和this.state中讀取。
用法:
component.forceUpdate(callback)
雖然確實有一些使用forceUpdate()方法的用例,但最好在需要時使用掛鉤,道具,狀態和上下文來對組件進行re-render處理。
默認情況下,當組件的state或props改變時,組件將重新渲染。如果你的render()方法依賴于一些其他的數據,你可以告訴React組件需要通過調用forceUpdate()重新渲染。
調用forceUpdate()會導致組件跳過shouldComponentUpdate(),直接調用render()。這將觸發組件的正常生命周期方法,包括每個子組件的shouldComponentUpdate()方法。
forceUpdate就是重新render。有些變量不在state上,當時你又想達到這個變量更新的時候,刷新render;或者state里的某個變量層次太深,更新的時候沒有自動觸發render。這些時候都可以手動調用forceUpdate自動觸發render
Sub.js class Sub extends React.Component{ construcotr(){ super(); this.name = "yema"; } refChangeName(name){ this.name = name; this.forceUpdate(); } render(){ return (<div>{this.name}</div>); } } App.js class App extends React.Component{ handleClick(){ this.subRef.refChangeName("yemafuren"); } render(){ return (<div> <Sub ref={(sub)=>{this.subRef = sub;}} /> <button onClick={this.handleClick}>click</button> </div>); } }
讀到這里,這篇“react中的forceupdate怎么用”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。