Maison interface Web js tutoriel Questions amusantes JavaScript : injection de dépendances

Questions amusantes JavaScript : injection de dépendances

Feb 13, 2017 pm 04:18 PM

Vous devez avoir entendu parler du modèle Dependency Injection (DI), n'est-ce pas ?

Qu'il s'agisse du framework back-end populaire Spring ou de la tendance front-end angular.js, l'injection de dépendances est visible partout.

Le terme est un peu obscur, mais l'idée de base est très simple.

En utilisant un dicton courant, « Si tu veux du vent, tu auras du vent, si tu veux de la pluie, tu auras de la pluie » , ou en d'autres termes « Quand tu as nourriture, tu ouvres la bouche, et quand tu as des vêtements, tu tends les mains » .

Vous êtes peut-être encore un peu confus après avoir entendu mon explication. Laissez-moi d'abord vous donner un exemple.

Voici quelques modules, ils sont aussi appelés "dépendances" et sont stockés dans un objet de hachage :


var deps = {
  'firstDependency': function () {return 'this is firstDependency';},
  'secondDepency': function () {return 'this is secondDepency';},
};
Copier après la connexion

Voici un gestionnaire d'injection de dépendances, qui sera nouveau le moment venu :


var DI = function (dependency) {
  this.dependency = dependency;
};
Copier après la connexion

dans nouveau, passez deps en paramètre.

D'accord, vient maintenant le nœud du problème, ce qu'il faut écrire :


DI.prototype.inject = function (func) {......};
Copier après la connexion

Cette méthode d'injection est liée au prototype de DI , reçoit une fonction en paramètre.

Alors comment l'utiliser ?


	var di = new DI(deps);

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

	myDependentFunc();
Copier après la connexion


Observons d'abord la fonction anonyme transmise par inject. Elle représente l'exigence et c'est là que nous devons injecter.

Jetons d'abord un coup d'œil à ses paramètres formels

secondDepency, firstDependency
Copier après la connexion

Il y a ici deux paramètres, qui représentent deux exigences. Le moment venu, nous analyserons ces deux paramètres et trouverons des liens. modules.

D'accord, revenons à l'écriture de la fonction d'injection, que devons-nous faire dans la première étape ?

Récupérez d'abord la forme toString() de la fonction transmise par inject :


	
	//第一步
	DI.prototype.inject = function (func) {
		func.toString();
	};
Copier après la connexion


Ensuite, analyser cette String de caractère, retrouver tous les paramètres formels :


	
	//第二步
	DI.prototype.inject = function (func) {
		var args = findArgs(func.toString());
	};
Copier après la connexion

Comment écrire la méthode findArgs ? Vous pouvez utiliser des expressions régulières ou la segmentation et l'interception de chaînes. J'utilise cette dernière ici.


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();
    });
};
Copier après la connexion

Après avoir trouvé tous les paramètres formels, la troisième étape consiste à trouver la fonction de module correspondante dans la table de hachage du module et à la stocker dans la liste de paramètres réelle.

realArgs fait référence à la liste des paramètres réels :


	
	//第三步
	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);
			}
		}
		//......
	};
Copier après la connexion


La dernière étape est Inject , inject renvoie une fonction anonyme Lorsque la fonction anonyme est exécutée, la liste de paramètres réelle est obtenue via la fermeture et injectée dans 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);
    };
}
Copier après la connexion

De cette manière, une version simple de la fonction d'injection est complétée.
Ce qui précède est une question JavaScript intéressante : le contenu de l'injection de dépendances. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois (www.php.cn) !

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Un guide étape par étape pour comprendre l'injection de dépendances dans Angular Un guide étape par étape pour comprendre l'injection de dépendances dans Angular Dec 02, 2022 pm 09:14 PM

Cet article vous guidera à travers l'injection de dépendances, présentera les problèmes que l'injection de dépendances résout et sa méthode d'écriture native, et parlera du framework d'injection de dépendances d'Angular. J'espère qu'il vous sera utile !

Comment utiliser l'injection de dépendances (Dependency Injection) dans le framework Phalcon Comment utiliser l'injection de dépendances (Dependency Injection) dans le framework Phalcon Jul 30, 2023 pm 09:03 PM

Introduction à la méthode d'utilisation de l'injection de dépendances (DependencyInjection) dans le framework Phalcon : Dans le développement logiciel moderne, l'injection de dépendances (DependencyInjection) est un modèle de conception courant visant à améliorer la maintenabilité et la testabilité du code. En tant que framework PHP rapide et peu coûteux, le framework Phalcon prend également en charge l'utilisation de l'injection de dépendances pour gérer et organiser les dépendances des applications. Cet article vous présentera comment utiliser le framework Phalcon

Modèle d'injection de dépendance dans le passage des paramètres de la fonction Golang Modèle d'injection de dépendance dans le passage des paramètres de la fonction Golang Apr 14, 2024 am 10:15 AM

Dans Go, le mode d'injection de dépendances (DI) est implémenté via le passage de paramètres de fonction, y compris le passage de valeurs et le passage de pointeurs. Dans le modèle DI, les dépendances sont généralement transmises sous forme de pointeurs pour améliorer le découplage, réduire les conflits de verrouillage et prendre en charge la testabilité. En utilisant des pointeurs, la fonction est découplée de l'implémentation concrète car elle ne dépend que du type d'interface. Le passage du pointeur réduit également la surcharge liée au passage d'objets volumineux, réduisant ainsi les conflits de verrouillage. De plus, le modèle DI facilite l'écriture de tests unitaires pour les fonctions utilisant le modèle DI, car les dépendances peuvent être facilement simulées.

Injection de dépendances à l'aide du framework de tests unitaires JUnit Injection de dépendances à l'aide du framework de tests unitaires JUnit Apr 19, 2024 am 08:42 AM

Pour tester l'injection de dépendances à l'aide de JUnit, le résumé est le suivant : Utiliser des objets fictifs pour créer des dépendances : l'annotation @Mock peut créer des objets fictifs de dépendances. Définir les données de test : la méthode @Before s'exécute avant chaque méthode de test et est utilisée pour définir les données de test. Configurer le comportement fictif : la méthode Mockito.when() configure le comportement attendu de l'objet fictif. Vérifier les résultats : assertEquals() affirme vérifier si les résultats réels correspondent aux valeurs attendues. Application pratique : vous pouvez utiliser un framework d'injection de dépendances (tel que Spring Framework) pour injecter des dépendances et vérifier l'exactitude de l'injection et le fonctionnement normal du code via les tests unitaires JUnit.

Go Language : Guide d'injection de dépendances Go Language : Guide d'injection de dépendances Apr 07, 2024 pm 12:33 PM

Réponse : En langage Go, l’injection de dépendances peut être implémentée via des interfaces et des structures. Définissez une interface qui décrit le comportement des dépendances. Créez une structure qui implémente cette interface. Injectez des dépendances via des interfaces en tant que paramètres dans les fonctions. Permet un remplacement facile des dépendances lors des tests ou dans différents scénarios.

Injection de dépendances et conteneur de services pour les fonctions PHP Injection de dépendances et conteneur de services pour les fonctions PHP Apr 27, 2024 pm 01:39 PM

Réponse : L'injection de dépendances et les conteneurs de services dans PHP aident à gérer les dépendances de manière flexible et à améliorer la testabilité du code. Injection de dépendances : faites passer les dépendances via le conteneur pour éviter la création directe au sein de la fonction, améliorant ainsi la flexibilité. Conteneur de services : stocke les instances de dépendance pour un accès facile dans le programme, améliorant encore le couplage lâche. Cas pratique : l'exemple d'application démontre l'application pratique de l'injection de dépendances et des conteneurs de services, injectant des dépendances dans le contrôleur, reflétant les avantages du couplage lâche.

Comment utiliser l'injection de dépendances pour les tests unitaires dans Golang ? Comment utiliser l'injection de dépendances pour les tests unitaires dans Golang ? Jun 02, 2024 pm 08:41 PM

L'utilisation de l'injection de dépendances (DI) dans les tests unitaires Golang peut isoler le code à tester, simplifiant ainsi la configuration et la maintenance des tests. Les bibliothèques DI populaires incluent wire et go-inject, qui peuvent générer des stubs de dépendance ou des simulations pour les tests. Les étapes des tests DI comprennent la définition des dépendances, la configuration des cas de test et l'affirmation des résultats. Un exemple d'utilisation de DI pour tester une fonction de gestion des requêtes HTTP montre à quel point il est facile d'isoler et de tester du code sans dépendances ni communication réelles.

Expliquez le concept d'injection de dépendance (DI) dans PHP. Expliquez le concept d'injection de dépendance (DI) dans PHP. Apr 05, 2025 am 12:07 AM

La valeur fondamentale de l'utilisation de l'injection de dépendance (DI) dans PHP réside dans la mise en œuvre d'une architecture de système à couplage vaguement. DI réduit les dépendances directes entre les classes en fournissant des dépendances en externe, en améliorant la testabilité et la flexibilité du code. Lorsque vous utilisez DI, vous pouvez injecter des dépendances via des constructeurs, des méthodes de point de consigne ou des interfaces et gérer les cycles de vie et les dépendances d'objet en combinaison avec des conteneurs IOC.

See all articles