組件的生命周期可分成三個狀態:
•Mounting:已插入真實 DOM
•Updating:正在被重新渲染
•Unmounting:已移出真實 DOM
生命周期的方法有:
•componentWillMount 在渲染前調用,在客戶端也在服務端。
•componentDidMount : 在第一次渲染后調用,只在客戶端。之后組件已經生成了對應的DOM結構,可以通過this.getDOMNode()來進行訪問。 如果你想和其他JavaScript框架一起使用,可以在這個方法中調用setTimeout, setInterval或者發送AJAX請求等操作(防止異部操作阻塞UI)。
•componentWillReceiveProps 在組件接收到一個新的prop時被調用。這個方法在初始化render時不會被調用。
•shouldComponentUpdate 返回一個布爾值。在組件接收到新的props或者state時被調用。在初始化時或者使用forceUpdate時不被調用。
可以在你確認不需要更新組件時使用。
•componentWillUpdate在組件接收到新的props或者state但還沒有render時被調用。在初始化時不會被調用。
•componentDidUpdate 在組件完成更新后立即調用。在初始化時不會被調用。
•componentWillUnmount在組件從 DOM 中移除的時候立刻被調用。
(DVA)定義組件一般有三種方式:
// 1. 傳統寫法 const App = React.createClass({}); // 2. es6 的寫法 class App extends React.Component({}); // 3. stateless 的寫法(我們推薦的寫法) const App = (props) => ({});
其中第1種是我們(DVA)不推薦的寫法,第2種是在你的組件涉及 react 的生命周期方法的時候采用這種寫法,而第3種則是我們一般推薦的寫法。
以上這篇老生常談js-react組件生命周期就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。