成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

React-Redux源碼剖析

Shimmer / 3274人閱讀

摘要:為了能夠更好的使用這個(gè)工具,今天就對(duì)它進(jìn)行一下源碼剖析。它內(nèi)部的關(guān)鍵代碼是在不指定的時(shí)候等于,這就意味著的源碼剖析到此結(jié)束,謝謝觀看當(dāng)然如果指定了剖析就還得繼續(xù)。好了,源碼剖析到此結(jié)束,謝謝觀看

React-Redux是用在連接React和Redux上的。如果你想同時(shí)用這兩個(gè)框架,那么React-Redux基本就是必須的了。為了能夠更好的使用這個(gè)工具,今天就對(duì)它進(jìn)行一下源碼剖析。

Provider

一個(gè)React組件,一般你的rootApp要放倒這個(gè)組件內(nèi)部渲染。它很簡(jiǎn)單,最關(guān)鍵的作用就是在context中放入Redux的store,方便子組件獲取。關(guān)鍵代碼:

getChildContext() {
    return { store: this.store }
}

Provider.childContextTypes = {
   store: storeShape.isRequired
}

這樣connect的組件就可以獲取store,使用store的方法。

connect

首選connect是個(gè)可以執(zhí)行兩次的柯里化函數(shù),第一次傳入的參數(shù)相當(dāng)于一系列的定制化東西,第二次傳入的是你要連接的React組件,然后返回一個(gè)新的React組件。
第一次執(zhí)行時(shí)傳入的參數(shù)是mapStateToProps, mapDispatchToProps, mergeProps, options這四個(gè)。首先會(huì)對(duì)這幾個(gè)參數(shù)進(jìn)行處理,代碼如下:

//決定組件會(huì)不會(huì)因state改變而更新
const shouldSubscribe = Boolean(mapStateToProps)
//如果不傳遞這個(gè)參數(shù)使用默認(rèn)state => ({})
const mapState = mapStateToProps || defaultMapStateToProps

//mapDispatchToProps的處理,最后的情況實(shí)際是使用bindActionCreators處理
let mapDispatch
if (typeof mapDispatchToProps === "function") {
    mapDispatch = mapDispatchToProps
} else if (!mapDispatchToProps) {
    mapDispatch = defaultMapDispatchToProps
} else {
    mapDispatch = wrapActionCreators(mapDispatchToProps)
}

//不傳遞就使用默認(rèn)值
const finalMergeProps = mergeProps || defaultMergeProps
const { pure = true, withRef = false } = options

第二次執(zhí)行函數(shù)接收的參數(shù)是個(gè)React組件:WrappedComponent,之后返回一個(gè)新的React組件Connect。

return hoistStatics(Connect, WrappedComponent)

把WrappedComponent的非React屬性拷貝到Connect上。下面詳細(xì)說(shuō)下Connect。

Connect

一個(gè)React組件

Connect.contextTypes = {
    store: storeShape
}

所以它可以從context中獲取Provider放的store。

constructor

在constructor中:

//獲取store
this.store = props.store || context.store
const storeState = this.store.getState()
//把store的state作為組件的state,后面通過(guò)更新state更新組件
this.state = { storeState }
//清除組件的狀態(tài),內(nèi)部是一系列的標(biāo)示還原
this.clearCache()
render

然后是render方法,在掛載的時(shí)候,會(huì)經(jīng)過(guò)一系列的判斷和計(jì)算,比如使用mapState計(jì)算nextStateProps,并和this.stateProps對(duì)比是否發(fā)生改變,如果發(fā)生改變:

nextDispatchProps = mapState(store.getState(), [props])
this.stateProps = nextDispatchProps

使用mapDispatch計(jì)算nextDispatchProps,并和this.dispatchProps對(duì)比是否發(fā)生改變,如果發(fā)生改變:

nextMergedProps = mapDispatch(dispatch, [props])
this.dispatchProps = nextMergedProps

如果上面的兩個(gè)對(duì)比有一個(gè)發(fā)生改變,就會(huì)繼續(xù)使用finalMergeProps來(lái)計(jì)算最終的數(shù)據(jù)合并結(jié)果nextMergedProps,并和this.mergedProps對(duì)比是否發(fā)生改變,如果發(fā)生改變:

nextMergedProps = finalMergeProps(this.stateProps, this.dispatchProps, this.props)
this.mergedProps = nextMergedProps

如果上面的對(duì)比確定發(fā)生改變

if (withRef) {
  this.renderedElement = createElement(WrappedComponent, {
      ...this.mergedProps,
      ref: "wrappedInstance"
  })
 } else {
  this.renderedElement = createElement(WrappedComponent,
      this.mergedProps
  )
 }
  return this.renderedElement

如果withRef等于true就會(huì)增加ref屬性,然后可以通過(guò)getWrappedInstance方法獲取DOM。如果前面說(shuō)的這些對(duì)比的結(jié)果都是false,就會(huì)直接返回this.renderedElement,組件不進(jìn)行任何更新。當(dāng)然組件掛載的時(shí)候前面的對(duì)比都會(huì)返回true。

componentDidMount

它內(nèi)部的關(guān)鍵代碼是:

if (shouldSubscribe && !this.unsubscribe) {
    this.unsubscribe = this.store.subscribe(this.handleChange.bind(this))
    this.handleChange()
}

在不指定mapStateToProps的時(shí)候shouldSubscribe等于false,這就意味著React-Redux的源碼剖析到此結(jié)束,謝謝觀看!當(dāng)然如果指定了mapStateToProps剖析就還得繼續(xù)。看到代碼沒(méi)有,竟然使用subscribe,意味著只要執(zhí)行dispatch,handleChange就會(huì)執(zhí)行。至此組件已經(jīng)掛載完畢,后面的代碼執(zhí)行需要有外界因素了,比如父組件傳遞新的props、執(zhí)行dispatch。

componentWillReceiveProps

組件還實(shí)現(xiàn)了componentWillReceiveProps這個(gè)React生命周期中的方法:

componentWillReceiveProps(nextProps) {
    if (!pure || !shallowEqual(nextProps, this.props)) {
        this.haveOwnPropsChanged = true
    }
}

看到pure的重要性了吧,如果pure被設(shè)置為false就意味著不管屬性是否淺相等this.haveOwnPropsChanged總是會(huì)被設(shè)置為true,而這會(huì)導(dǎo)致后面一系列的為了更新而進(jìn)行的計(jì)算,所以pure為true是可以給你的性能帶來(lái)幫助的,不過(guò)它默認(rèn)就是true。這里設(shè)置this.haveOwnPropsChanged等于true是給通過(guò)直接通過(guò)父組件傳遞props更新組件帶來(lái)可能,當(dāng)然需要配合mapStateToProps, mapDispatchToProps, mergeProps這三個(gè)函數(shù),如果它們都沒(méi)有利用ownProps,最終組件還是不能通過(guò)這種方式更新。

handleChange

下面假定觸發(fā)了一次dispatch,這個(gè)時(shí)候handleChange就會(huì)執(zhí)行,如果state沒(méi)有發(fā)生改變,并且pure為true,就什么都不做直接返回,pure又在性能上立功了。如果state發(fā)生了改變會(huì)再做一些計(jì)算對(duì)比,比如計(jì)算this.stateProps。最后是在要更新的時(shí)候會(huì):

this.hasStoreStateChanged = true
this.setState({ storeState })

調(diào)用setState來(lái)觸發(fā)組件更新。這里其實(shí)意味著只要store的state發(fā)生改變,所有的mapStateToProps、 mapDispatchToProps、mergeProps都會(huì)執(zhí)行。

shouldComponentUpdate

這個(gè)時(shí)候會(huì)調(diào)用它內(nèi)部實(shí)現(xiàn)的shouldComponentUpdate,用來(lái)提高性能。

shouldComponentUpdate() {
    return !pure || this.haveOwnPropsChanged || this.hasStoreStateChanged
}

但是怎么感覺(jué)這個(gè)并沒(méi)有什么用呢?可能是我理解不深,因?yàn)闊o(wú)論是父組件更新props還是state改變這里總是返回true,而不管改變的是不是這個(gè)組件關(guān)心的數(shù)據(jù)。沒(méi)辦法又進(jìn)入了render方法。

好了,源碼剖析到此結(jié)束,謝謝觀看!

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/80034.html

相關(guān)文章

  • 我的源碼閱讀之路:redux源碼剖析

    摘要:到月底了,小明的爸爸的單位發(fā)了工資總計(jì)塊大洋,拿到工資之后第一件的事情就是上交,毫無(wú)疑問(wèn)的,除非小明爸爸不要命了。當(dāng)小明的爸爸收到這個(gè)通知之后,心的一塊大石頭也就放下來(lái)了。下面我們正式開(kāi)始我們的源碼閱讀之旅。 前言 用過(guò)react的小伙伴對(duì)redux其實(shí)并不陌生,基本大多數(shù)的React應(yīng)用用到它。一般大家用redux的時(shí)候基本都不會(huì)單獨(dú)去使用它,而是配合react-redux一起去使用...

    CloudwiseAPM 評(píng)論0 收藏0
  • Redux源碼剖析

    摘要:的存在是為了避免在執(zhí)行過(guò)程中,發(fā)生改變,導(dǎo)致錯(cuò)誤。保證的修改不會(huì)影響。在內(nèi)部關(guān)鍵代碼是第一行用來(lái)調(diào)用,并將執(zhí)行的結(jié)果賦給。符合這個(gè)標(biāo)準(zhǔn)的會(huì)被放入中。以上基本是的全部關(guān)鍵代碼剖析,簡(jiǎn)單而強(qiáng)大。 前面寫(xiě)了《React組件性能優(yōu)化》《Redux性能優(yōu)化》《React-Redux性能優(yōu)化》,但是都沒(méi)有從這些框架的實(shí)現(xiàn)上講為什么?這次就從源碼上來(lái)分析一下這些框架的實(shí)現(xiàn)原理,以更深入的理解這些框架...

    Yangder 評(píng)論0 收藏0
  • 解密Redux: 從源碼開(kāi)始

    摘要:接下來(lái)筆者就從源碼中探尋是如何實(shí)現(xiàn)的。其實(shí)很簡(jiǎn)單,可以簡(jiǎn)單理解為一個(gè)約束了特定規(guī)則并且包括了一些特殊概念的的發(fā)布訂閱器。新舊中存在的任何都將收到先前的狀態(tài)。這有效地使用來(lái)自舊狀態(tài)樹(shù)的任何相關(guān)數(shù)據(jù)填充新?tīng)顟B(tài)樹(shù)。 Redux是當(dāng)今比較流行的狀態(tài)管理庫(kù),它不依賴(lài)于任何的框架,并且配合著react-redux的使用,Redux在很多公司的React項(xiàng)目中起到了舉足輕重的作用。接下來(lái)筆者就從源碼...

    remcarpediem 評(píng)論0 收藏0
  • 純Redux原理分析

    摘要:調(diào)用鏈中最后一個(gè)會(huì)接受真實(shí)的的方法作為參數(shù),并借此結(jié)束調(diào)用鏈??偨Y(jié)我們常用的一般是除了和之外的方法,那個(gè)理解明白了,對(duì)于以后出現(xiàn)的問(wèn)題會(huì)有很大幫助,本文只是針對(duì)最基礎(chǔ)的進(jìn)行解析,之后有機(jī)會(huì)繼續(xù)解析對(duì)他的封裝 前言 雖然一直使用redux+react-redux,但是并沒(méi)有真正去講redux最基礎(chǔ)的部分理解透徹,我覺(jué)得理解明白redux會(huì)對(duì)react-redux有一個(gè)透徹的理解。 其實(shí),...

    sumory 評(píng)論0 收藏0
  • FE.SRC-React實(shí)戰(zhàn)與原理筆記

    摘要:異步實(shí)戰(zhàn)狀態(tài)管理與組件通信組件通信其他狀態(tài)管理當(dāng)需要改變應(yīng)用的狀態(tài)或有需要更新時(shí),你需要觸發(fā)一個(gè)把和載荷封裝成一個(gè)。的行為是同步的。所有的狀態(tài)變化必須通過(guò)通道。前端路由實(shí)現(xiàn)與源碼分析設(shè)計(jì)思想應(yīng)用是一個(gè)狀態(tài)機(jī),視圖與狀態(tài)是一一對(duì)應(yīng)的。 React實(shí)戰(zhàn)與原理筆記 概念與工具集 jsx語(yǔ)法糖;cli;state管理;jest單元測(cè)試; webpack-bundle-analyzer Sto...

    PumpkinDylan 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<