React 的 pureRenderMixin 的實(shí)現(xiàn)

pureRenderMixin 的實(shí)現(xiàn)主要是修改了組件的 shouldComponentUpdate 方法的實(shí)現(xiàn)對于組件 state 或 props 變化過后先進(jìn)行一個 shallowCompare(淺比較)的過程在決定是否需要 render 組件從而優(yōu)化相關(guān)渲染性能。

實(shí)現(xiàn)代碼主要為:

// 源文件地址: https://github.com/facebook/react/blob/master/src/addons/ReactComponentWithPureRenderMixin.js
var ReactComponentWithPureRenderMixin = {
    shouldComponentUpdate: function(nextProps, nextState){
        return shallowCompare(this, nextProps, nextState);
    }
}

上面的代碼使用了一個 shallowCompare 的方法,實(shí)現(xiàn)代碼如下:

// 源文件地址 https://github.com/facebook/react/blob/master/src/addons/shallowCompare.js
function shallowCompare(instance, nextProps, nextState) {
    return (
        !shallowEqual(instance.props, nextProps) ||
        !shallowEqual(instance.state, nextState)
    );
}

可以看到主要的實(shí)現(xiàn)都放到 shallowEqual 這個方法里面,這個方法使用的是一個第三方庫用于淺比較兩個對象是否相等。
淺的意義在于,不會去迭代的對對象進(jìn)行深度比較,只取得對象的 key 的值進(jìn)行比較,對于基礎(chǔ)類型直接比較值是否相等,對于引用類型只比較其引用是否相等。

簡版的實(shí)現(xiàn)如下:

function shallowEqual(objA, objB) {
    if(objA === objB) {
        return true;
    }
    var keyA = Object.keys(objA),
        keyB = Object.keys(objB);

    if(keyA.length != keyB.length) {
        return false;
    }

    for(var idx = 0, len = keyA.length; idx < len; idx++ ) {
        var key = keyA[idx];
        
        if(!objB.hasOwnProperty(key)) {
            return false;
        }
        var valueA = objA[key],
              valueB = objB[key];
        // 無差別比較,引用類型比較引用,基礎(chǔ)類型直接比較值
        if(valueA !== valueB) {
            return false;
        }
    }
    return true;
}

完整 shallowEqual 實(shí)現(xiàn)代碼地址: https://github.com/dashed/shallowequal/blob/master/src/index.js

更多關(guān)于React渲染性能優(yōu)化,以及為什么使用 pureRenderMixin 和 Immutable Date 的相關(guān)知識可以查看 React爬坑秘籍(一)——提升渲染性能

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,147評論 25 708
  • 深入JSX date:20170412筆記原文其實(shí)JSX是React.createElement(componen...
    gaoer1938閱讀 8,183評論 2 35
  • 原教程內(nèi)容詳見精益 React 學(xué)習(xí)指南,這只是我在學(xué)習(xí)過程中的一些閱讀筆記,個人覺得該教程講解深入淺出,比目前大...
    leonaxiong閱讀 2,945評論 1 18
  • 我放生了一盆花 當(dāng)然,我首先是打碎了那個盆 這個在人類眼里精致的瓷器 對她而言不過是一張裹腳布 實(shí)際上我認(rèn)為,她那...
    根號四等于二閱讀 657評論 0 51
  • 上課時檢查課文背誦,一個男生突然舉手,我眼神示意他稍等,讓正在進(jìn)行中的同學(xué)背完??墒撬€是執(zhí)著的高舉手掌,我只好讓...
    素衣煙霞閱讀 323評論 0 0

友情鏈接更多精彩內(nèi)容