国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題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 源碼中的依賴注入方法

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

React 源碼中的依賴注入方法

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

一、前言

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

二、依賴注入的基本概念

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

在控制不反轉的情況下,某個類如果依賴另一個類,它會自己來創建依賴:

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

class Dinner {
 constructor(name) {
 this.name = name;
 }
}

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

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

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

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

三、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 都是一個對象,對象內定義了一個或多個 inject 的方法來注入對應的內容。以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 個方法注入進去的。

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

// 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 中調用的方法ReactDefaultInjection.inject()。

上述各個文件整體的調用關系如下:

四、總結

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

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

文檔

React 源碼中的依賴注入方法

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

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 欧美一欧美一区二三区性 | 中文字幕第一页亚洲 | 免费国产最新进精品视频 | 一区二区三区中文字幕 | 成人精品视频一区二区三区 | 国产精品视_精品国产免费 国产精品视频第一区二区三区 | 国产成人在线免费视频 | 在线欧美日韩制服国产 | 成人a免费视频播放 | 久久91精品国产一区二区 | 小说区 亚洲 自拍 另类 | 久久亚洲伊人中字综合精品 | 中文字幕一区久久久久 | 亚洲色图欧美自拍 | 亚洲欧美国产精品 | 日本a中文字幕 | 久久成人国产精品免费 | 亚洲视频五区 | 久久er| 8x成人在线 | 国产a级一级久久毛片 | 国产99视频精品免费观看7 | 亚洲欧美天堂网 | 精品一区 二区三区免费毛片 | 精品一区二区三区在线播放 | 国产成人精品亚洲一区 | 九九国产精品视频 | 欧美三页| 最刺激黄a大片免费观看 | 国产精品高清久久久久久久 | 亚洲视频在线免费播放 | 欧洲日韩视频二区在线 | 免费一区二区视频 | 国产最新视频 | 欧美日韩国内 | 国产又黄又a又潮娇喘视频 国产淫视频 | 国模冰冰炮交图后02 | zozozo欧美人禽交另类视频 | 爱色电影 | 亚洲精品免费视频 | 国产在线视频在线观看 |