摘要:,和的流行,讓生命周期這個名詞常常出現(xiàn)在前端們的口中,以至于面試中最常見的一個問題也是介紹下的生命周期以及使用方法聽起來高大上的生命周期,其實也就是一些普通的方法,只是在不同的時期傳參調(diào)用它們而已。
React,Vue 和 Angular 的流行,讓“生命周期”這個名詞常常出現(xiàn)在前端們的口中,以至于面試中最常見的一個問題也是:
介紹下React, Vue的生命周期以及使用方法?
聽起來高大上的“生命周期”,其實也就是一些普通的方法,只是在不同的時期傳參調(diào)用它們而已。我們可以照著React的生命周期,自己模擬一個簡單的類,并讓這個類擁有一些生命周期鉤子
我們希望實現(xiàn)一個State類,這個類擁有以下方法和生命周期:
方法:
setState
生命周期:
willStateUpdate (nextState): 狀態(tài)將要改變
shouldStateUpdate (nextState): 是否要讓狀態(tài)改變,只有返回true才會改變狀態(tài)
didStateUpdate (prevState): 狀態(tài)改變后(要是 shouldStateUpdate 返回的不為true則不會調(diào)用)
class User extends State { constructor(name) { super(); this.state = { name } } willStateUpdate(nextState) { console.log("willStateUpdate", nextState); } shouldStateUpdate(nextState) { console.log("shouldStateUpdate", nextState); if (nextState.name === this.state.name) { return false; } return true; } didStateUpdate(prevState) { console.log("didStateUpdate", prevState); } } const user = new User("deepred"); user.setState({ name: "hentai" });
首先,你需要知道JavaScript的面向?qū)ο蠡A(chǔ)知識,如果還不是很了解,可以先看下這篇文章JavaScript的面向?qū)ο?/p> setState的實現(xiàn)
class State { constructor() { this.state = {}; } setState(nextState) { const preState = this.state; this.state = { ...preState, ...nextState, }; } }
class User extends State { constructor(name) { super(); this.state = { name } } } const user = new User("tc"); user.setState({age: 10}); // {name: "tc", age: 10}
在React中,setState方法只會改變特定屬性的值,因此,我們需要在方法里用一個變量preState保留之前的state,然后通過展開運算符,將新舊state合并
willStateUpdate的實現(xiàn)willStateUpdate是state狀態(tài)更新前調(diào)用的。因此只要在合并state前調(diào)用willStateUpdate就行
class State { constructor() { this.state = {}; } setState(nextState) { // 更新前調(diào)用willStateUpdate this.willStateUpdate(nextState); const preState = this.state; this.state = { ...preState, ...nextState, }; } willStateUpdate() { // 默認啥也不做 } }
class User extends State { constructor(name) { super(); this.state = { name } } // 覆蓋父級同名方法 willStateUpdate(nextState) { console.log("willStateUpdate", nextState); } } const user = new User("tc"); user.setState({age: 10}); // {name: "tc", age: 10}shouldStateUpdate的實現(xiàn)
我們規(guī)定只有shouldStateUpdate返回true時,才更新state。因此在合并state前,還要調(diào)用shouldStateUpdate
class State { constructor() { this.state = {}; } setState(nextState) { this.willStateUpdate(nextState); const update = this.shouldStateUpdate(nextState); if (update) { const preState = this.state; this.state = { ...preState, ...nextState, }; } } willStateUpdate() { // 默認啥也不做 } shouldStateUpdate() { // 默認返回true,一直都是更新 return true; } }
class User extends State { constructor(name) { super(); this.state = { name } } // 覆蓋父級同名方法 willStateUpdate(nextState) { console.log("willStateUpdate", nextState); } // 自定義何時更新 shouldStateUpdate(nextState) { if (nextState.name === this.state.name) { return false; } return true; } } const user = new User("tc"); user.setState({ age: 10 }); // {name: "tc", age: 10} user.setState({ name: "tc", age: 11 }); // 沒有更新didStateUpdate的實現(xiàn)
懂了willStateUpdate也就知道didStateUpdate如何實現(xiàn)了
class State { constructor() { this.state = {}; } setState(nextState) { this.willStateUpdate(nextState); const update = this.shouldStateUpdate(nextState); if (update) { const preState = this.state; this.state = { ...preState, ...nextState, }; this.didStateUpdate(preState); } } willStateUpdate() { // 默認啥也不做 } didStateUpdate() { // 默認啥也不做 } shouldStateUpdate() { // 默認返回true,一直都是更新 return true; } }
class User extends State { constructor(name) { super(); this.state = { name } } // 覆蓋父級同名方法 willStateUpdate(nextState) { console.log("willStateUpdate", nextState); } // 覆蓋父級同名方法 didStateUpdate(preState) { console.log("didStateUpdate", preState); } shouldStateUpdate(nextState) { console.log("shouldStateUpdate", nextState); if (nextState.name === this.state.name) { return false; } return true; } } const user = new User("tc"); user.setState({ age: 10 }); user.setState({ name: "tc", age: 11 });
通過幾十行的代碼,我們就已經(jīng)實現(xiàn)了一個自帶生命周期的State類了!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/101028.html
摘要:例如下面的代碼組件生命周期鉤子函數(shù)在組件掛載完成后立即被調(diào)用組件掛載完成渲染結(jié)果以上就是一個常規(guī)的組件編寫方式,不過我們還可以通過觀察上面的代碼,發(fā)現(xiàn)幾個有趣的地方中有一個函數(shù)是組件生命周期鉤子函數(shù)。 如何編寫一個React組件 在React的世界里,通常是用class來聲明一個組件的,它必須繼承自React.Component。例如下面的代碼: // MyFirstComponent...
摘要:在前端頁面中,把用純對象表示,負責顯示,兩者做到了最大限度的分離。的顯示與否和的布爾值有關(guān),還是只關(guān)注數(shù)據(jù)的變化。兩個組件的布爾值通過兩個臨近的按鈕控制,初始值和的結(jié)果都是。組件的聲明在組件上,則完全沒有進入生命周期。 開始前說一說 吐槽 首先, 文章有謬誤的地方, 請評論, 我會進行驗證修改。謝謝。 vue真是個好東西,但vue的中文文檔還有很大的改進空間,有點大雜燴的意思,對于怎么...
摘要:天氣預報小程序說了很多小程序開發(fā)的基礎(chǔ)準備,下面就結(jié)合個人實際練手項目天氣預報小程序簡單說明。物料準備從需求結(jié)果導向,天氣程序首先要能獲取到當前所在地天氣狀況,再次可以自由選擇某地,知道其天氣狀況。 前言 學習了一段時間小程序,大致過了兩遍開發(fā)文檔,抽空做個自己的天氣預報小程序,全當是練手,在這記錄下。小程序開發(fā)的安裝、注冊和接入等流程就不羅列了,在小程序接入指南已經(jīng)寫得很清楚了,以下...
摘要:就像人們對更新移動應(yīng)用程序和操作系統(tǒng)感到興奮一樣,開發(fā)人員也應(yīng)該對更新框架感到興奮。錯誤邊界是一種組件。注意將作為值傳遞進去并不會導致使用。如果兩者不同,則返回一個用于更新狀態(tài)的對象,否則就返回,表示不需要更新狀態(tài)。 就像人們對更新移動應(yīng)用程序和操作系統(tǒng)感到興奮一樣,開發(fā)人員也應(yīng)該對更新框架感到興奮。不同框架的新版本具有新特性和開箱即用的技巧。 下面是將現(xiàn)有應(yīng)用程序從 React 15...
閱讀 1406·2021-11-08 13:14
閱讀 761·2021-09-23 11:31
閱讀 1051·2021-07-29 13:48
閱讀 2790·2019-08-29 12:29
閱讀 3385·2019-08-29 11:24
閱讀 1910·2019-08-26 12:02
閱讀 3703·2019-08-26 10:34
閱讀 3447·2019-08-23 17:07