首頁 web前端 js教程 JavaScript趣題:依賴注入

JavaScript趣題:依賴注入

Feb 13, 2017 pm 04:18 PM

你想必聽過依賴注入(DI)模式吧?

無論是後端火的一塌糊塗的Spring框架,還是前端潮流angular.js,處處可見依賴注入的身影。

它這個名詞有些晦澀,但核心的思想卻很簡單。

用一句俗話說就是,「要風得風,要雨得雨」,或者說是「飯來張口,衣來伸手」

你聽了我這麼一解釋,大概還有些迷糊,我就先上一個例子。

下面是一些模組,他們也被稱為「依賴」,被儲存在一個hash物件中:


var deps = {
  'firstDependency': function () {return 'this is firstDependency';},
  'secondDepency': function () {return 'this is secondDepency';},
};
登入後複製

下面則是一個依賴注入的管理器,到時候是要new出來的:


var DI = function (dependency) {
  this.dependency = dependency;
};
登入後複製

new的時候,就把deps當參數傳進去了。

好,現在問題的關鍵來了,我們要寫的東西:


DI.prototype.inject = function (func) {......};
登入後複製

這個inject注入方法綁定在DI的原型上,接收一個函數作為參數。

那它該怎麼使用呢?


	var di = new DI(deps);

	var myDependentFunc = di.inject(function (secondDepency, firstDependency) {
	    firstDependency();
	    secondDepency();
	});

	myDependentFunc();
登入後複製


大家先觀察一下這個inject傳入的匿名函數,它代表需求,是我們需要注入的地方。

先看看它的形參,

secondDepency, firstDependency
登入後複製

這裡有兩個參數,即代表兩個需求,到時候,我們要分析這兩個參數,找出相關模組。

好,回到inject函數的編寫問題上來,第一步該怎麼做?

先取得inject傳進來函數的toString()形式:


	
	//第一步
	DI.prototype.inject = function (func) {
		func.toString();
	};
登入後複製


接著,分析這個字串,找出所有的形參使用正規或字串分割截取都可以,這裡我用的後者。


	
	//第二步
	DI.prototype.inject = function (func) {
		var args = findArgs(func.toString());
	};
登入後複製

找出所有的形參後,第三步,從模組hash表中,找出對應的模組函數,存放進實參列表中。


realArgs

指涉

實參列表

String.prototype.trim=function(){
  return this.replace(/(^\s*)|(\s*$)/g, "");
};

var findArgs = function(funcStr){
    var bracket1 = funcStr.indexOf("(");
    var bracket2 = funcStr.indexOf(")");
    var argsStr = funcStr.slice(bracket1+1,bracket2);
    var args = argsStr.split(",");
    return args.map(function(e){
        return e.trim();
    });
};
登入後複製

最後一步是

注入
,inject返回一個閉函數,並使用匿名函數,透過函數來執行的真實包實進行。 ,注入

func


	
	//第三步
	DI.prototype.inject = function (func) {
		var args = findArgs(func.toString());
		var realArgs = [];
		for(var i=0;i<args.length;i++){
			var dep = this.dependency[args[i]];
			if(dep){
				realArgs.push(dep);
			}
		}
		//......
	};
登入後複製
這樣,一個簡單版的注入函數就完成了。 以上就是JavaScript趣題:依賴注入的內容,更多相關內容請關注PHP中文網(www.php.cn)!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1665
14
CakePHP 教程
1424
52
Laravel 教程
1321
25
PHP教程
1269
29
C# 教程
1249
24
手把手帶你了解Angular中的依賴注入 手把手帶你了解Angular中的依賴注入 Dec 02, 2022 pm 09:14 PM

這篇文章帶大家了解一下依賴注入,介紹一下依賴注入解決的問題和它原生的寫法是什麼,並聊聊Angular的依賴注入框架,希望對大家有所幫助!

在Phalcon框架中使用依賴注入(Dependency Injection)的方法 在Phalcon框架中使用依賴注入(Dependency Injection)的方法 Jul 30, 2023 pm 09:03 PM

在Phalcon框架中使用依賴注入(DependencyInjection)的方法引言:在現代的軟體開發中,依賴注入(DependencyInjection)是一種常見的設計模式,旨在提高程式碼的可維護性和可測試性。而Phalcon框架作為一個快速、低耗的PHP框架,也支援使用依賴注入來管理和組織應用程式的依賴關係。本文將向您介紹如何在Phalcon框架中

使用JUnit單元測試框架進行依賴注入 使用JUnit單元測試框架進行依賴注入 Apr 19, 2024 am 08:42 AM

針對使用JUnit測試依賴注入,摘要如下:使用模擬物件建立依賴項:@Mock註解可建立依賴項的模擬物件。設定測試資料:@Before方法在每個測試方法前執行,用於設定測試資料。配置模擬行為:Mockito.when()方法配置模擬物件的預期行為。驗證結果:assertEquals()斷言檢查實際結果與預期值是否相符。實際應用:可使用依賴注入框架(如SpringFramework)注入依賴項,透過JUnit單元測試驗證注入的正確性和程式碼的正常運作。

Golang函數參數傳遞中的依賴注入模式 Golang函數參數傳遞中的依賴注入模式 Apr 14, 2024 am 10:15 AM

在Go中,依賴注入(DI)模式透過函數參數傳遞實現,類型包括值傳遞和指標傳遞。在DI模式中,依賴項通常以指標傳遞,以提高解耦性、減少鎖爭用和支援可測試性。透過使用指針,函數與特定實作解耦,因為它只依賴介面類型。指標傳遞還可以減少傳遞大物件的開銷,從而減少鎖爭用。此外,DI模式可以輕鬆地為使用DI模式的函數編寫單元測試,因為可以輕鬆地模擬依賴項。

Go語言:依賴注入指南 Go語言:依賴注入指南 Apr 07, 2024 pm 12:33 PM

答案:在Go語言中,依賴注入可以透過介面和結構體來實現。定義一個描述依賴項行為的介面。建立一個實作該介面的結構體。在函數中透過介面作為參數注入依賴項。允許在測試或不同場景中輕鬆替換依賴項。

解釋PHP中依賴注射(DI)的概念。 解釋PHP中依賴注射(DI)的概念。 Apr 05, 2025 am 12:07 AM

在PHP中使用依賴注入(DI)的核心價值在於實現松耦合的系統架構。 DI通過外部提供依賴的方式減少類之間的直接依賴關係,提高代碼的可測試性和靈活性。使用DI時,可以通過構造函數、設值方法或接口注入依賴,並結合IoC容器管理對像生命週期和依賴關係。

如何在 Golang 中使用依賴注入進行單元測試? 如何在 Golang 中使用依賴注入進行單元測試? Jun 02, 2024 pm 08:41 PM

在Golang單元測試中使用依賴注入(DI)可以隔離要測試的程式碼,簡化測試設定和維護。流行的DI庫包括wire和go-inject,它們可以產生依賴項樁或模擬,供測試使用。 DI測試的步驟包括設定依賴項、設定測試案例和斷言結果。使用DI測試HTTP請求處理函數的範例表明,它可以輕鬆隔離和測試程式碼,無需實際依賴項或通訊。

PHP 函數的依賴注入與服務容器 PHP 函數的依賴注入與服務容器 Apr 27, 2024 pm 01:39 PM

答:PHP中的依賴注入和服務容器有助於靈活地管理依賴項,提高程式碼可測試性。依賴注入:透過容器傳遞依賴項,避免在函數內直接創建,提升彈性。服務容器:儲存依賴項實例,方便在程式中訪問,進一步增強鬆散耦合。實戰案例:範例應用程式演示依賴注入和服務容器的實際應用,將相依性注入到控制器,體現鬆散耦合優勢。

See all articles