這篇文章主要介紹了React中的render什么時候執行過程,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
成都創新互聯主營泰山網站建設的網絡公司,主營網站建設方案,成都app開發,泰山h5微信小程序開發搭建,泰山網站營銷推廣歡迎泰山等地區企業咨詢我們都知道Render在組件實例化和存在期時都會被執行。實例化在componentWillMount執行完成后就會被執行,這個沒什么好說的。在這里我們主要分析存在期組件更新時的執行。
存在期的方法包含:
- componentWillReceiveProps
- shouldComponentUpdate
- componentWillUpdate
- render
- componentDidUpdate
這些方法會在組件的狀態或者屬性發生發生變化時被執行,如果我們使用了Redux,那么就只有當屬性發生變化時被執行。下面我們將從幾個場景來分析屬性的變化。
首先我們創建了HelloWorldComponent,代碼如下所示:
import * as React from "react"; class HelloWorldComponent extends React.Component { constructor(props) { super(props); } componentWillReceiveProps(nextProps) { console.log('hello world componentWillReceiveProps'); } render() { console.log('hello world render'); const { onClick, text } = this.props; return ( <button onClick={onClick}> {text} </button> ); } } HelloWorldComponent.propTypes = { onClick: React.PropTypes.func, }; export default HelloWorldComponent;
AppComponent組件的代碼如下:
class MyApp extends React.Component { constructor(props) { super(props); this.onClick = this.onClick.bind(this); } onClick() { console.log('button click'); this.props.addNumber(); } render() { return ( <HelloWorld onClick={this.onClick} text="test"></HelloWorld> ) } } const mapStateToProps = (state) => { return { count: state.count } }; const mapDispatchToProps = { addNumber }; export default connect(mapStateToProps, mapDispatchToProps)(MyApp);
這里我們使用了Redux,但是代碼就不貼出來了,其中addNumber方法會每次點擊時將count加1。
這個時候當我們點擊button時,你覺得子組HelloWorldComponent的render方法會被執行嗎?
如圖所示,當我們點擊button時,子組件的render方法被執行了。可是從代碼來看,組件綁定的onClick和text都沒有發生改變啊,為何組件會更新呢?
如果在子組件的componentWillReceiveProps添加這個log:console.log(‘isEqual', nextProps === this.props); 輸出會是true還是false呢?
是的,你沒有看錯,輸出的是false。這也是為什么子組件會更新了,因為屬性值發生了變化,并不是說我們綁定在組件上的屬性值。每次點擊button時會觸發state發生變化,進而整個組件重新render了,但這并不是我們想要的,因為這不必要的渲染會極其影響我們應用的性能。
在react中除了繼承Component創建組件之外,還有個PureComponent。通過該組件就可以避免這種情況。下面我們對代碼做點修改再來看效果。修改如下:
class HelloWorldComponent extends React.PureComponent
這次在點擊button時發生了什么呢?
雖然componentWillReceiveProps依然會執行,但是這次組件沒有重新render。
所以,我們對于無狀態組件,我們應該盡量使用PureComponent,需要注意的是PureComponent只關注屬性值,也就意味著對象和數組發生了變化是不會觸發render的。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“React中的render什么時候執行過程”這篇文章對大家有幫助,同時也希望大家多多支持創新互聯成都網站設計公司,關注創新互聯成都網站設計公司行業資訊頻道,更多相關知識等著你來學習!
另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、網站設計器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
網頁名稱:React中的render什么時候執行過程-創新互聯
分享路徑:http://vcdvsql.cn/article36/hoepg.html
成都網站建設公司_創新互聯,為您提供外貿建站、網站排名、企業建站、云服務器、微信公眾號、網站設計公司
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯