<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        React 源碼中的依賴注入方法

        來源:懂視網(wǎng) 責編:小采 時間:2020-11-27 22:04:19
        文檔

        React 源碼中的依賴注入方法

        React 源碼中的依賴注入方法:一、前言 依賴注入(Dependency Injection)這個概念的興起已經(jīng)有很長時間了,把這個概念融入到框架中達到出神入化境地的,非Spring莫屬。然而在前端領(lǐng)域,似乎很少會提到這個概念,難道前端的代碼就不需要解耦嗎?前端的代碼就沒有依賴了?本文將以 Rea
        推薦度:
        導讀React 源碼中的依賴注入方法:一、前言 依賴注入(Dependency Injection)這個概念的興起已經(jīng)有很長時間了,把這個概念融入到框架中達到出神入化境地的,非Spring莫屬。然而在前端領(lǐng)域,似乎很少會提到這個概念,難道前端的代碼就不需要解耦嗎?前端的代碼就沒有依賴了?本文將以 Rea

        一、前言

        依賴注入(Dependency Injection)這個概念的興起已經(jīng)有很長時間了,把這個概念融入到框架中達到出神入化境地的,非Spring莫屬。然而在前端領(lǐng)域,似乎很少會提到這個概念,難道前端的代碼就不需要解耦嗎?前端的代碼就沒有依賴了?本文將以 React 的源碼為例子,看看它是如何使用依賴注入這一設計模式的。

        二、依賴注入的基本概念

        在看代碼之前,有必要先簡單介紹一下依賴注入的基本概念。依賴注入和控制反轉(zhuǎn)(Inversion of Control),這兩個詞經(jīng)常一起出現(xiàn)。一句話表述他們之間的關(guān)系:依賴注入是控制反轉(zhuǎn)的一種實現(xiàn)方式。另一種方式叫依賴查找(Dependency Lookup)。

        在控制不反轉(zhuǎn)的情況下,某個類如果依賴另一個類,它會自己來創(chuàng)建依賴:

        class Person {
         eat() {
         const dinner = new Dinner('法國菜');
         console.log('開飯啦!,今晚自己做:', dinner.name);
         }
        }
        
        class Dinner {
         constructor(name) {
         this.name = name;
         }
        }
        
        

        假設一個人要吃飯,如果控制不反轉(zhuǎn),就需要自己來做,像上面的代碼一樣要自己new Dinner。

        如果使用控制反轉(zhuǎn),吃什么就不用自己費腦子了,別人給我做好放到我面前,我直接吃就好!

        class Person {
         eat(dinner) {
         console.log('開飯啦!,今晚有大廚給我做:', dinner.name);
         }
        }
        

        也就是說,不需要自己來創(chuàng)建依賴的對象了,由外部傳入,這就是依賴注入!

        三、React 中的依賴注入

        眾所周知,React 除了可以在瀏覽器運行外(ReactDOM),也可以制作 App 在手機端運行(ReactNative)。而兩者有大量的代碼都是可以共享的,這就是依賴注入的使用場景了。

        我們來看下具體是如何注入的:

        // ReactDOM.js
        var ReactDefaultInjection = require('ReactDefaultInjection');
        ReactDefaultInjection.inject();
        
        // ReactNative.js
        var ReactNativeDefaultInjection = require('ReactNativeDefaultInjection');
        ReactNativeDefaultInjection.inject();
        
        

        注入的位置都在框架代碼最開始加載的位置。下面以 ReactDOM 為例子,詳細講解注入的邏輯。

        先來看看需要注入的對象都有哪些,定義在 ReactInjection.js 這個文件當中:

        var DOMProperty = require('DOMProperty');
        var EventPluginHub = require('EventPluginHub');
        var EventPluginUtils = require('EventPluginUtils');
        var ReactComponentEnvironment = require('ReactComponentEnvironment');
        var ReactEmptyComponent = require('ReactEmptyComponent');
        var ReactBrowserEventEmitter = require('ReactBrowserEventEmitter');
        var ReactHostComponent = require('ReactHostComponent');
        var ReactUpdates = require('ReactUpdates');
        
        var ReactInjection = {
         Component: ReactComponentEnvironment.injection,
         DOMProperty: DOMProperty.injection,
         EmptyComponent: ReactEmptyComponent.injection,
         EventPluginHub: EventPluginHub.injection,
         EventPluginUtils: EventPluginUtils.injection,
         EventEmitter: ReactBrowserEventEmitter.injection,
         HostComponent: ReactHostComponent.injection,
         Updates: ReactUpdates.injection,
        };
        
        module.exports = ReactInjection;
        
        

        這里面每一個 injection 都是一個對象,對象內(nèi)定義了一個或多個 inject 的方法來注入對應的內(nèi)容。以ReactUpdates.injection為例子:

        // ReactUpdates.js
        var ReactUpdatesInjection = {
         injectReconcileTransaction: function (ReconcileTransaction) {
         ...
         ReactUpdates.ReactReconcileTransaction = ReconcileTransaction;
         },
        
         injectBatchingStrategy: function (_batchingStrategy) {
         ...
         batchingStrategy = _batchingStrategy;
         },
        };
        
        var ReactUpdates = {
         ...
         injection: ReactUpdatesInjection,
        };
        
        

        可以看到 ReactUpdates 依賴的ReactReconcileTransaction和batchingStrategy就是通過這 2 個方法注入進去的。

        有了上面的內(nèi)容,相當于定義好需要依賴的內(nèi)容了。下一步就是創(chuàng)建具體的依賴內(nèi)容,然后注入到需要的地方:

        // ReactDefaultInjection.js
        var ReactInjection = require('ReactInjection');
        var ReactReconcileTransaction = require('ReactReconcileTransaction');
        var ReactDefaultBatchingStrategy = require('ReactDefaultBatchingStrategy');
        
        ...
        
        function inject() {
         ...
        
         ReactInjection.Updates.injectReconcileTransaction(
         ReactReconcileTransaction
         );
         ReactInjection.Updates.injectBatchingStrategy(
         ReactDefaultBatchingStrategy
         );
        }
        
        

        這里的 ReactInjection.Updates 等于 ReactUpdates.injection 這個對象。而 inject 方法,就是在前文的 ReactDOM.js 中調(diào)用的方法ReactDefaultInjection.inject()。

        上述各個文件整體的調(diào)用關(guān)系如下:

        四、總結(jié)

        本文介紹了依賴注入的基本概念,并結(jié)合 React 的源碼講解具體的使用場景。這樣做的主要目的是解耦,可以根據(jù)實際的上下文傳入不同的依賴對象,優(yōu)雅的實現(xiàn)了代碼的抽象與復用。

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        React 源碼中的依賴注入方法

        React 源碼中的依賴注入方法:一、前言 依賴注入(Dependency Injection)這個概念的興起已經(jīng)有很長時間了,把這個概念融入到框架中達到出神入化境地的,非Spring莫屬。然而在前端領(lǐng)域,似乎很少會提到這個概念,難道前端的代碼就不需要解耦嗎?前端的代碼就沒有依賴了?本文將以 Rea
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 免费国产成人高清在线观看麻豆| 99xxoo视频在线永久免费观看| xxx毛茸茸的亚洲| 亚洲精品二三区伊人久久| 噜噜噜亚洲色成人网站| 国产免费AV片在线观看播放| 无码人妻久久一区二区三区免费| 免费毛片在线看片免费丝瓜视频| 亚洲精品一级无码鲁丝片| 午夜亚洲国产理论秋霞| 色天使亚洲综合在线观看| www一区二区www免费| 久久久久久精品免费看SSS| mm1313亚洲精品无码又大又粗| 亚洲伊人tv综合网色| 337P日本欧洲亚洲大胆精品| 精品一区二区三区无码免费视频| 亚洲国产精品碰碰| 亚洲精品国产av成拍色拍| 久久久久免费精品国产 | 成全高清在线观看免费| 天天拍拍天天爽免费视频| 亚洲精品无码av人在线观看| 久久精品熟女亚洲av麻豆| 亚洲国产a级视频| 日本视频在线观看永久免费 | 亚洲精品美女久久777777| 免费无码中文字幕A级毛片| 亚洲免费观看在线视频| 一级毛片全部免费播放| 精品日韩99亚洲的在线发布| 国产成人精品高清免费| 亚洲国产综合精品| 亚洲综合免费视频| 亚洲视频在线播放| 性xxxx视频免费播放直播| 亚洲日韩国产二区无码 | 九九免费久久这里有精品23| 国产一级高清视频免费看| 国产成人人综合亚洲欧美丁香花| 国内精品99亚洲免费高清|