摘要:的返回值將作為的參數(shù),如果返回,則不更新,不能返回或以外的值,否則會警告。在更新之前調(diào)用,此時已更新返回值作為的第個參數(shù)一般用于獲取之前的數(shù)據(jù)語法是從的返回值,默認(rèn)是的使用場景一般是獲取組建更新之前的滾動條位置。
React16 后的各功能點(diǎn)是多個版本陸陸續(xù)續(xù)迭代增加的,本篇文章的講解是建立在 16.6.0 版本上更新概覽
本篇文章主旨在介紹 React16 之后版本中新增或修改的地方,所以對于 React16 之前版本的功能,本篇文章當(dāng)作您已充分了解了,不再贅述
從 React v16.0 ~ React v16.6 的更新概覽(只涉及部分常用api):
React v16.0
render支持返回數(shù)組和字符串
支持自定義 DOM 屬性
減少文件體積
React v16.3
createContext
createRef
生命周期函數(shù)的更新
React v16.4
更新 getDerivedStateFromProps
React v16.6
memo
lazy
Suspense
static contextType
static getDerivedStateFromError
React v16.7(~Q1 2019)
Hooks
接下來將針對影響較大,使用頻率較高的更新點(diǎn)逐一講解。
純函數(shù)的PureComponent我們知道,對 React 組件的性能優(yōu)化,shouldComponentUpdate函數(shù)是很重要的一啪,所以 React 才會在 React.Component的基礎(chǔ)上增加了React.PureComponent,但是對于非class類的純函數(shù)寫法,卻沒法增加這樣的便捷處理。
對于這個問題,React16.6 增加了React.memo這個高階組件
一般使用方式:
const C = React.memo(props => { // xxx })
React.memo的實(shí)現(xiàn)類似React.PureComponent,所以它內(nèi)部是對對象進(jìn)行淺比較。
React.memo允許你自定義比較方法,如下:
// 函數(shù)的返回值為 true 時則更新組件,反之則不更新 const equalMethod = (prevProps, nextProps): boolean => { // 定義你的比較邏輯 } const C = React.memo(props => { // xxx }, equalMethod)新的生命周期函數(shù)是怎樣的
React生命周期分為三個階段:掛載、更新、卸載,React16后又多了一個異常,我們一一看下。
constructor
static getDerivedStateFromProps
render
componentDidMount
render和componentDidMount較 React16 之前無變化。對于掛載過程,我們著重看下constructor、componentWillMount和static getDerivedStateFromProps。
constructor初始化 state
注意:應(yīng)避免使用props給state賦值,這樣的話, state的初始化可以提到constructor外面處理
constructor(props) { super(props); this.state = { x: 1, // y: props.y, // 避免這樣做,后面我們會講應(yīng)該怎樣處理 } }
給方法綁定this
constructor(props) { super(props); this.handleClick = this.handleClick.bind(this); }
但是,以上兩件事放到constructor外面處理會更簡單些,如下:
class C extends React.Component { state = { x: 1 } handleClick = (e) => { // xxx } }
所以,React16 以后用到constructor的場景會變少。
componentWillMount可以看到,componentWillMount在 React16 中被“刪掉”了(這樣說其實(shí)是有問題的,因?yàn)?React 并未真正刪除該生命周期函數(shù),只是告誡開發(fā)者,該函數(shù)在未來版本中會被廢棄掉),那么問題就出現(xiàn)了,原先在這個生命周期中的做的事情,現(xiàn)在該放到哪里去做呢?
首先問自己一個問題,原先的時候都在這個生命周期里做什么?答案是大部分時候會在這里做 AJAX 請求,然后執(zhí)行setState重新渲染。
然而在componentWillMount里做 AJAX 請求實(shí)在不是一個明智之舉,因?yàn)閷τ谕瑯?gòu)項(xiàng)目中,componentWillMount是會被調(diào)用的。
還有人會在這里面初始化state,關(guān)于state的初始化,請參看樓上小節(jié)。
綜上所述,componentWillMount其實(shí)本來沒有什么主要作用,如果你的代碼規(guī)范,去掉的話,不會對現(xiàn)在的項(xiàng)目產(chǎn)生什么影響。
static getDerivedStateFromProps上面我們講到,應(yīng)避免使用props給state賦值,但是在 React16 前我們都是這么做的,現(xiàn)在如果不讓這么操作了,那該在哪里處理這塊邏輯呢? React16 給出的答案就是 static getDerivedStateFromProps。
掛載組件時,該靜態(tài)方法會在render前執(zhí)行;更新組件時,該靜態(tài)方法會在shouldComponentUpdate前執(zhí)行。
class C extends React.Component { state = { y: 0 } static getDerivedStateFromProps(props, state): State { if(props.y !== state.y) { return { y: props.y }; } } }
getDerivedStateFromProps的返回值將作為setState的參數(shù),如果返回null,則不更新state,不能返回object 或 null 以外的值,否則會警告。
getDerivedStateFromProps是一個靜態(tài)方法,是拿不到實(shí)例this的,所以開發(fā)者應(yīng)該將該函數(shù)設(shè)計(jì)成純函數(shù)。
這樣,有沒有發(fā)現(xiàn)componentWillReceiveProps也就沒有用武之地了?是的,React16 把它也“刪掉”了(這樣說其實(shí)是有問題的,因?yàn)?react 并未真正刪除該生命周期函數(shù),只是告誡開發(fā)者,該函數(shù)在未來版本中會被廢棄掉,建議使用更好的getSnapshotBeforeUpdate 或 getDerivedStateFromProps)
更新 生命周期函數(shù)的執(zhí)行順序static getDerivedStateFromProps
shouldComponentUpdate
render
getSnapshotBeforeUpdate
componentDidUpdate
static getDerivedStateFromProps前面已經(jīng)介紹過了,而其他的幾個生命周期函數(shù)與 React16 之前基本無異,所以這里主要介紹下getSnapshotBeforeUpdate。
getSnapshotBeforeUpdate在 React 更新 DOM 之前調(diào)用,此時state已更新;
返回值作為componentDidUpdate的第3個參數(shù);
一般用于獲取render之前的 DOM 數(shù)據(jù)
語法:
class C extends React.Component { getSnapshotBeforeUpdate (prevProps, prevState): Snapshot { } componentDidUpdate(prevProps, prevState, snapshot) { // snapshot 是從 getSnapshotBeforeUpdate 的返回值,默認(rèn)是 null } }
getSnapshotBeforeUpdate 的使用場景一般是獲取組建更新之前的滾動條位置。
卸載componentWillUnmount
較之前無變化。
異常componentDidCatch 這個函數(shù)是 React16 新增的,用于捕獲組件樹的異常,如果render()函數(shù)拋出錯誤,則會觸發(fā)該函數(shù)。可以按照 try catch 來理解和使用,在可能出現(xiàn)錯誤的地方,使用封裝好的包含 componentDidCatch 生命周期的組建包裹可能出錯的組件。
class PotentialError extends React.Component { state = { error: false, } componentDidCatch(error, info) { console.error(info); this.setState({ error }); } render() { if (this.state.error) { return出錯了,請打卡控制臺查看詳細(xì)錯誤!
; } return this.props.children; } }
如:
const Demo = () => () {{a: 1}}
這樣,Demo 組件即使直接使用對象作為子組件也不會報錯了,因?yàn)楸?PotentialError 接收了。
新生命周期的完整demo看看穿上新生命周期這身新衣服后的樣子吧
import React from "react" export default class MyComponent extends React.Component { constructor(props) { super(props); // 初始化state方式(1) this.state = { } } static defaultProps = { } // 初始化state方式(2) state = { } static getDerivedStateFromProps(props, state) { return state } componentDidCatch(error, info) { } render() { } componentDidMount() { } shouldComponentUpdate(nextProps, nextState) { } getSnapshotBeforeUpdate(prevProps, prevState) { } componentDidUpdate(prevProps, prevState, snapshot) { } componentWillUnmount() { } }Suspense Hooks time slicing
【未完待續(xù)】
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/102234.html
摘要:但是,最后一步,事件怎么綁定呢這塊沒有深入研究了,不過我想,應(yīng)該這樣去實(shí)現(xiàn)也是沒有問題的。的具體做法是,把方法放到了一個叫做的組件上去實(shí)現(xiàn)這個功能,然后再把內(nèi)容放進(jìn)這個組件。其他的邏輯比如顯示隱藏之類,全部都放到組件自身上去實(shí)現(xiàn)。 1、Dialog組件提供什么功能,解決什么問題? zent的Dialog組件,使用姿勢是這樣的(代碼摘自zent官方文檔:https://www.youza...
摘要:詳解十大常用設(shè)計(jì)模式力薦深度好文深入理解大設(shè)計(jì)模式收集各種疑難雜癥的問題集錦關(guān)于,工作和學(xué)習(xí)過程中遇到過許多問題,也解答過許多別人的問題。介紹了的內(nèi)存管理。 延遲加載 (Lazyload) 三種實(shí)現(xiàn)方式 延遲加載也稱為惰性加載,即在長網(wǎng)頁中延遲加載圖像。用戶滾動到它們之前,視口外的圖像不會加載。本文詳細(xì)介紹了三種延遲加載的實(shí)現(xiàn)方式。 詳解 Javascript十大常用設(shè)計(jì)模式 力薦~ ...
摘要:并根據(jù)官網(wǎng)文檔的語法順序,寫了對應(yīng)的的語法,并附一個教程。和受限元素一樣,使用事件可以監(jiān)聽值的變化。有一個初始值,但這個值用戶可以改變并會反應(yīng)到界面上。 寫在前面 以前寫Vue寫慣了,心血來潮,寫起了react。并根據(jù)Vue官網(wǎng)文檔的語法順序,寫了對應(yīng)的React的語法,并附一個教程demo。 教程的github地址:Close2React 項(xiàng)目使用框架版本主要有 react(15.4...
摘要:騰訊前端技術(shù)大會和全球技術(shù)領(lǐng)導(dǎo)力峰會都于上周閉幕,我翻看了下講稿,有價值的參考還是不少。騰訊前端大會下載騰訊前端大會是由騰訊主辦,廣邀國內(nèi)外的前端大牛,有著名流行框架的作者知名前端書籍的作者工程化方面的權(quán)威等。 showImg(https://segmentfault.com/img/bVQk0r?w=757&h=427); 共 2462 字,讀完需 4 分鐘。騰訊前端技術(shù)大會(TFC...
摘要:比如在的時候組件掛載的時候會根據(jù)指定的參數(shù)繼續(xù)向下執(zhí)行,則會在掛載的時候還沒發(fā)生點(diǎn)擊事件就直接執(zhí)行了父組件的函數(shù)。即中轉(zhuǎn)函數(shù)的效果,保證了時的函數(shù)都是并且也防止了子組件在掛載時,順著調(diào)用父組件的函數(shù)從而避免了一系列錯誤。 寫在前面 以前寫Vue寫慣了,心血來潮,寫起了react。 github地址:Close2React 項(xiàng)目使用框架版本主要有 react(15.4.1) + reac...
閱讀 2077·2021-11-16 11:45
閱讀 578·2021-11-04 16:12
閱讀 1379·2021-10-08 10:22
閱讀 858·2021-09-23 11:52
閱讀 4142·2021-09-22 15:47
閱讀 3521·2021-09-22 15:07
閱讀 492·2021-09-03 10:28
閱讀 1737·2021-09-02 15:21