Rumah hujung hadapan web tutorial 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';},
};
Salin selepas log masuk

下面则是一个依赖注入的管理器,到时候是要new出来的:


var DI = function (dependency) {
  this.dependency = dependency;
};
Salin selepas log masuk

new的时候,就把deps当参数传进去了。

好,现在问题的关键来了,我们要编写的东西:


DI.prototype.inject = function (func) {......};
Salin selepas log masuk

这个inject注入方法绑定在DI的原型上,接收一个函数作为参数。

那它该怎么使用呢?


	var di = new DI(deps);

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

	myDependentFunc();
Salin selepas log masuk


大家先观察一下这个inject传入的匿名函数,它代表需求,是我们需要注入的地方。

先看看它的形参,

secondDepency, firstDependency
Salin selepas log masuk

这里有两个参数,即代表两个需求,到时候,我们要分析这两个参数,查找相关模块。

好,回到inject函数的编写问题上来,第一步该怎么做?

先获取inject传进来函数的toString()形式:


	
	//第一步
	DI.prototype.inject = function (func) {
		func.toString();
	};
Salin selepas log masuk


接着,分析这个字符串,找出所有的形参:


	
	//第二步
	DI.prototype.inject = function (func) {
		var args = findArgs(func.toString());
	};
Salin selepas log masuk

findArgs方法该怎么编写?使用正则或者字符串分割截取都可以,这里我用的后者。


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();
    });
};
Salin selepas log masuk

找出所有的形参后,第三步,从模块hash表中,找出对应的模块函数,存放进实参列表中。

realArgs指代实参列表


	
	//第三步
	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);
			}
		}
		//......
	};
Salin selepas log masuk


最后一步才是注入,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);
        }
    }
    return function(){
        return func.apply(null,realArgs);
    };
}
Salin selepas log masuk

这样,一个简单版的注入函数就完工了。
以上就是JavaScript趣题:依赖注入的内容,更多相关内容请关注PHP中文网(www.php.cn)!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Panduan langkah demi langkah untuk memahami suntikan pergantungan dalam Angular Panduan langkah demi langkah untuk memahami suntikan pergantungan dalam Angular Dec 02, 2022 pm 09:14 PM

Artikel ini akan membawa anda melalui suntikan pergantungan, memperkenalkan masalah yang diselesaikan oleh suntikan pergantungan dan kaedah penulisan asalnya, dan bercakap tentang rangka kerja suntikan pergantungan Angular saya harap ia akan membantu semua orang.

Cara menggunakan suntikan kebergantungan (Dependency Injection) dalam rangka kerja Phalcon Cara menggunakan suntikan kebergantungan (Dependency Injection) dalam rangka kerja Phalcon Jul 30, 2023 pm 09:03 PM

Pengenalan kepada kaedah menggunakan suntikan kebergantungan (DependencyInjection) dalam rangka kerja Phalcon: Dalam pembangunan perisian moden, suntikan kebergantungan (DependencyInjection) ialah corak reka bentuk biasa yang bertujuan untuk meningkatkan kebolehselenggaraan dan kebolehujian kod. Sebagai rangka kerja PHP yang pantas dan kos rendah, rangka kerja Phalcon juga menyokong penggunaan suntikan kebergantungan untuk mengurus dan mengatur kebergantungan aplikasi. Artikel ini akan memperkenalkan anda cara menggunakan rangka kerja Phalcon

Corak suntikan kebergantungan dalam lulus parameter fungsi Golang Corak suntikan kebergantungan dalam lulus parameter fungsi Golang Apr 14, 2024 am 10:15 AM

Dalam Go, mod suntikan kebergantungan (DI) dilaksanakan melalui hantaran parameter fungsi, termasuk hantaran nilai dan hantaran penunjuk. Dalam corak DI, kebergantungan biasanya diluluskan sebagai petunjuk untuk meningkatkan penyahgandingan, mengurangkan pertikaian kunci dan menyokong kebolehujian. Dengan menggunakan penunjuk, fungsi itu dipisahkan daripada pelaksanaan konkrit kerana ia hanya bergantung pada jenis antara muka. Hantaran penunjuk juga mengurangkan overhed menghantar objek besar, dengan itu mengurangkan pertengkaran kunci. Tambahan pula, corak DI memudahkan untuk menulis ujian unit untuk fungsi menggunakan corak DI kerana kebergantungan boleh dipermainkan dengan mudah.

Suntikan kebergantungan menggunakan rangka kerja ujian unit JUnit Suntikan kebergantungan menggunakan rangka kerja ujian unit JUnit Apr 19, 2024 am 08:42 AM

Untuk menguji suntikan kebergantungan menggunakan JUnit, ringkasannya adalah seperti berikut: Gunakan objek olok-olok untuk mencipta kebergantungan: Anotasi @Mock boleh mencipta objek olok-olok bagi kebergantungan. Tetapkan data ujian: Kaedah @Sebelum dijalankan sebelum setiap kaedah ujian dan digunakan untuk menetapkan data ujian. Konfigurasikan tingkah laku olok-olok: Kaedah Mockito.when() mengkonfigurasi gelagat yang dijangkakan bagi objek olok-olok. Sahkan keputusan: assertEquals() menegaskan untuk menyemak sama ada hasil sebenar sepadan dengan nilai yang dijangkakan. Aplikasi praktikal: Anda boleh menggunakan rangka kerja suntikan kebergantungan (seperti Rangka Kerja Spring) untuk menyuntik kebergantungan, dan mengesahkan ketepatan suntikan dan operasi biasa kod melalui ujian unit JUnit.

Bahasa Go: Panduan Suntikan Ketergantungan Bahasa Go: Panduan Suntikan Ketergantungan Apr 07, 2024 pm 12:33 PM

Jawapan: Dalam bahasa Go, suntikan kebergantungan boleh dilaksanakan melalui antara muka dan struktur. Tentukan antara muka yang menerangkan tingkah laku kebergantungan. Buat struktur yang melaksanakan antara muka ini. Suntikan kebergantungan melalui antara muka sebagai parameter dalam fungsi. Membenarkan penggantian mudah kebergantungan dalam ujian atau senario yang berbeza.

Suntikan ketergantungan dan bekas perkhidmatan untuk fungsi PHP Suntikan ketergantungan dan bekas perkhidmatan untuk fungsi PHP Apr 27, 2024 pm 01:39 PM

Jawapan: Suntikan ketergantungan dan bekas perkhidmatan dalam PHP membantu mengurus kebergantungan secara fleksibel dan meningkatkan kebolehujian kod. Suntikan kebergantungan: Lulus kebergantungan melalui bekas untuk mengelakkan penciptaan langsung dalam fungsi, meningkatkan fleksibiliti. Bekas perkhidmatan: menyimpan contoh pergantungan untuk akses mudah dalam program, meningkatkan lagi gandingan longgar. Kes praktikal: Aplikasi sampel menunjukkan aplikasi praktikal bekas suntikan kebergantungan dan perkhidmatan, menyuntik kebergantungan ke dalam pengawal, mencerminkan kelebihan gandingan longgar.

Bagaimana untuk menggunakan suntikan pergantungan untuk ujian unit di Golang? Bagaimana untuk menggunakan suntikan pergantungan untuk ujian unit di Golang? Jun 02, 2024 pm 08:41 PM

Menggunakan suntikan pergantungan (DI) dalam ujian unit Golang boleh mengasingkan kod yang akan diuji, memudahkan persediaan ujian dan penyelenggaraan. Perpustakaan DI yang popular termasuk wayar dan go-inject, yang boleh menjana stub pergantungan atau ejekan untuk ujian. Langkah-langkah ujian DI termasuk menetapkan kebergantungan, menyediakan kes ujian dan menegaskan keputusan. Contoh penggunaan DI untuk menguji fungsi pengendalian permintaan HTTP menunjukkan betapa mudahnya untuk mengasingkan dan menguji kod tanpa kebergantungan atau komunikasi sebenar.

Terangkan konsep suntikan ketergantungan (DI) dalam PHP. Terangkan konsep suntikan ketergantungan (DI) dalam PHP. Apr 05, 2025 am 12:07 AM

Nilai teras menggunakan suntikan ketergantungan (DI) dalam PHP terletak pada pelaksanaan seni bina sistem yang ditambah dengan longgar. DI mengurangkan kebergantungan langsung antara kelas dengan menyediakan kebergantungan secara luaran, meningkatkan kesesuaian kod dan fleksibiliti. Apabila menggunakan DI, anda boleh menyuntik kebergantungan melalui pembina, kaedah set-point, atau antara muka, dan menguruskan hayat objek dan kebergantungan dalam kombinasi dengan bekas IOC.

See all articles