91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

React 源碼中的依賴注入方法

發布時間:2020-07-09 09:58:36 來源:網絡 閱讀:335 作者:dolunbu 欄目:web開發

一、前言

依賴注入(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 源碼中的依賴注入方法

四、總結

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


文章同步發布: https://www.geek-share.com/detail/2752558290.html


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宜宾县| 闽清县| 四平市| 泰州市| 夹江县| 泰和县| 巴楚县| 武隆县| 松溪县| 德昌县| 磐石市| 永平县| 乌鲁木齐县| 黔江区| 高清| 沈丘县| 久治县| 杨浦区| 息烽县| 琼中| 五大连池市| 琼海市| 江北区| 富民县| 武乡县| 岳普湖县| 澎湖县| 吉木乃县| 九寨沟县| 南澳县| 长兴县| 高阳县| 南木林县| 叙永县| 拜泉县| 曲靖市| 盱眙县| 田林县| 军事| 江门市| 武隆县|