摘要:本次分析的源碼采用的是的版本核心接口提供了處理的工具集我們先來看看做了什么事情即當(dāng)為空時,返回不為時調(diào)用,最終返回一個數(shù)組這里說一下,可以通過傳入的對所有子組件進行操作,具體使用方法看下圖參數(shù)通過配合的例子把父組件的賦值給每個子組件我們先不
本次分析的源碼采用的是16.4.1的版本
核心接口React.Children
提供了處理 this.props.children 的工具集:
map
forEach
count
toArray
only
我們先來看看mapChildren做了什么事情
map: mapChildren
即當(dāng)children為空時,返回null;
不為null時調(diào)用mapIntoWithKeyPrefixInternal,最終返回一個result數(shù)組.
這里說一下,可以通過傳入的func對所有子組件進行操作,具體使用方法看下圖參數(shù)
通過配合cloneElement的例子:
class RadioGroup extends Component { constructor(props){ super(props); } renderChildren(props) { return React.Children.map(props.children, (child, index) => { if (child.type === RadioOption) return React.cloneElement(child, { // 把父組件的props.name賦值給每個子組件 name: props.name }) return child }) } render() { return ({this.renderChildren(this.props)}) } }
forEach、count、toArray我們先不看,先看下only
only: onlyChild
看注釋就能明白了
這個函數(shù)會返回第一個children,同時通過isValidElement判斷是不是唯一的一個,若不是會報錯
因為若只有一個那一定是一個Object對象,否則為一個數(shù)組
所以可以通過判斷是否為children是不是一個Object對象
我們來看下函數(shù)驗證一下
果然有個一判斷是否為Object的條件,剩下兩個是判斷是否為null和$$typeof是否為element
React.createRef
照舊看下源碼
這里發(fā)現(xiàn)用了Object.seal方法來封閉了refObject,即阻止添加新屬性并將所有現(xiàn)有屬性標(biāo)記為不可配置。當(dāng)前屬性的值只要可寫就可以改變,這里說下不可變(immutable)對象的幾個好處:
線程安全
易于理解
比可變對象有更高的安全性
createRef是React 16.3 發(fā)布的方法
同時還有一個用于高階組件的forwardRef
基本原理是通過劫持ref并且將之轉(zhuǎn)換成prop實現(xiàn)的
具體使用如下
function HOC(WrappedComponent) { class HOC extends React.Component { constructor(props){ super(props); } render() { const {forwardedRef, ...rest} = this.props; return; } } return React.forwardRef((props, ref) => { return ; });; } class Child extends React.Component{ constructor(props){ super(props); } render(){ return } } const LogProps = HOC(Child); class Father extends React.Component{ constructor(props){ super(props); this.myRef = React.createRef(); } componentDidMount(){ console.log(this.myRef.current); } render(){ return } }
React.Component 和 React.PureComponent
這里是Component
這里是PureComponent
這里是ComponentDummy
這里發(fā)現(xiàn)setState 和 forceUpdate方法掛在Component下,通過一個ComponentDummy的“偽組件”來當(dāng)作中介,使PureComponent也能訪問到setState 和 forceUpdate方法。
細心的可能發(fā)現(xiàn)這里有個objectAssign方法,這個方法把Component的原型跟PureComponent的原型合并了,也就是說PureComponent和Component共用了一個原型
這里的shouldUseNative()是對原生的assgin方法進行兼容性判斷,我把源碼貼出來,有興趣的可以看看
createFactory: createFactoryWithValidation
createElement: createElementWithValidation
在最后我們可以看到有一個判斷type === REACT_FRAGMENT_TYPE,這個REACT_FRAGMENT_TYPE是一個可以包裹碎片化元素的組件
用React.Fragment包裹碎片化的組件,可以寫作
<> ... > 但可能有的編譯器不支持,最好寫作...
看到現(xiàn)在都沒發(fā)現(xiàn)render方法的蹤影,源碼還沒讀完......
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/96705.html
摘要:因為版本將真正廢棄這三生命周期到目前為止,的渲染機制遵循同步渲染首次渲染,更新時更新時卸載時期間每個周期函數(shù)各司其職,輸入輸出都是可預(yù)測,一路下來很順暢。通過進一步觀察可以發(fā)現(xiàn),預(yù)廢棄的三個生命周期函數(shù)都發(fā)生在虛擬的構(gòu)建期間,也就是之前。 showImg(https://segmentfault.com/img/bVbweoj?w=559&h=300); 背景 前段時間準(zhǔn)備前端招聘事項...
摘要:卸載階段組件卸載和銷毀老版生命周期之前的生命周期初始化階段涉及個鉤子函數(shù)這些方法會在組件初始化的時候被調(diào)用,只跟實例的創(chuàng)建有關(guān)。 前言:React 的版本從 v15 到 v16.3 ,再到v16.4,現(xiàn)在最新的版本是 v16.8了。其中最大的變化可能是React Hooks的加入,而最令人困惑的卻是它的生命周期,新舊生命周期函數(shù)混雜在一起,難免會讓許多新來者有很多困惑。所以這一篇我們來...
摘要:在前端開發(fā)過程中,源碼解讀是必不可少的一個環(huán)節(jié),我們直接進入主題,注意當(dāng)前版本號。注意包文件僅僅是的必要的功能性的定義,它必須要結(jié)合一起使用下是,原生環(huán)境下是。 在前端開發(fā)過程中,源碼解讀是必不可少的一個環(huán)節(jié),我們直接進入主題,注意當(dāng)前 React 版本號 16.8.6。 注意:react 包文件僅僅是 React components 的必要的、功能性的定義,它必須要結(jié)合 React...
摘要:引言于發(fā)布版本,時至今日已更新到,且引入了大量的令人振奮的新特性,本文章將帶領(lǐng)大家根據(jù)更新的時間脈絡(luò)了解的新特性。其作用是根據(jù)傳遞的來更新。新增等指針事件。 1 引言 于 2017.09.26 Facebook 發(fā)布 React v16.0 版本,時至今日已更新到 React v16.6,且引入了大量的令人振奮的新特性,本文章將帶領(lǐng)大家根據(jù) React 更新的時間脈絡(luò)了解 React1...
摘要:布爾型,表示該幀里面沒有執(zhí)行回調(diào),超時了。這一處理機制在監(jiān)聽函數(shù)中實現(xiàn)作為,接受消息的時機將隨著線程的空閑程度起變化。 為什么是要有scheduler 首先要從js的是單線程模型來說起,Javascript執(zhí)行是會經(jīng)歷靜態(tài)編譯,動態(tài)解釋和事件循環(huán)做任務(wù)調(diào)度的過程,大致的流程如下(注意,該流程是以chrome瀏覽器內(nèi)核為標(biāo)準(zhǔn)的執(zhí)行流程,在node或者其他瀏覽器中,執(zhí)行流程會有所差異,但是...
閱讀 3717·2023-04-26 00:56
閱讀 2706·2021-09-30 10:01
閱讀 974·2021-09-22 15:30
閱讀 3934·2021-09-07 10:21
閱讀 1541·2021-09-02 15:40
閱讀 2774·2021-08-30 09:47
閱讀 1256·2021-08-16 10:57
閱讀 1875·2019-08-30 14:01