Maison interface Web js tutoriel Une analyse approfondie des principes d'injection de dépendances AngularJS

Une analyse approfondie des principes d'injection de dépendances AngularJS

Mar 28, 2018 pm 03:06 PM
angularjs 依赖注入

Cet article partage principalement avec vous une analyse approfondie du principe d'injection de dépendances AngularJS. Il a une bonne valeur de référence et j'espère qu'il sera utile à tout le monde. Suivons l’éditeur et jetons un coup d’œil.

Injection de dépendance : Injection de dépendance AbréviationDI

Exemple :

var xiaomi = new Xiaomi();     // 假设小米公司生产了一台xiaomi手机
createShipment(xiaomi);         //此方法能把货送给顾客,这叫做把小米手机注入到createShipment()方法
Copier après la connexion

Assumer à nouveau Lorsque la méthode createShipment() nécessite trois paramètres (téléphone portable, entreprise de messagerie, détails de la commande), elle a besoin de :

var xiaomi = new Xiaomi();     // 不仅要生产手机
var shipCompany = new ShipCompany();   // 还要自己建立个快递公司
var order = new Order();      // 还要自己建立线上线下平台做订单
createShipmentxiaomi,shipCompany,order);   // 虽然小米已经这么干了,但还是很累的
Copier après la connexion

En plus de ce qui précède Par exemple, Xiaomi N'y a-t-il pas d'autre moyen de vendre dans mon propre magasin ? Non seulement vous devez fabriquer des téléphones portables, mais vous devez aussi vous occuper des affaires et faire de la livraison express. Vous n'êtes pas fatigué ? En plus de le faire lui-même, Xiaomi peut également le vendre sur Taobao, JD.com, Suning et d'autres plateformes, et utiliser des sociétés express telles que Santong Yishun pour livrer les marchandises. C'est le problème que l'injection de dépendance doit résoudre. Utiliser Taobao, JD.com, SF Express et d'autres sociétés, c'est injecter un service de vente (sellService), un service de livraison express (sendService), etc. dans Xiaomi !

Inversion de contrôle : Inversion de contrôle AbréviationIOC

IOC fait référence au transfert du contrôle des dépendances de l'intérieur du code vers l'intérieur du code. Par exemple, Xiaomi a donné le pouvoir de vendre et de livrer des téléphones mobiles au monde extérieur. Quant à savoir si Taobao vend ou JD vend, si YTO livre ou SF Express, Xiaomi n'a pas à s'en soucier. téléphones portables. Laissez les questions professionnelles aux professionnels.

IOC est un mode de couplage lâche, et le moyen de mise en œuvre est l'injection de dépendances.

Injecteur :

constructeur(privé someService : SomeService) { ...}

Cette phrase signifie que ce composant déclare un someService L'attribut de indique que son type est SomeService, puis angular ira au fournisseur pour trouver SomeService< Une instance de 🎜 >, puis injectez cette instance dans someService.

提供器:

providers:[{provide:SomeService,useClass:SomeService}]

providers:[SomeService]//provideuseClass相同可简写为这个

例:

app.module.ts

@NgModule({  
    providers:[{provide:SellService,useClass:ShunfengService}],             // 这个是淘宝,用的顺丰
      // providers: [{provide:SellService,useClass:YuantongService}]          // 这个是京东,用的圆通})
product.component.ts
@Component({  ...
})
     export class ProductComponent implements OnInit {  product: Product;  constructor(sellService: SellService) {
        this.product = this.sellService.sendProduct();
  }}
Copier après la connexion

上面的代码怎么理解呢?

小米声明sellService对象(也是属性),叫sellService去卖手机,sellService呼叫售卖服务,这个服务是SellService类型的(线上销售),那么angular就会去提供器里面找谁在提供这个售卖服务,至于是淘宝还是京东那要看提供器里面的,用的哪个快递公司就更加不需要小米公司来管了。angular找到SellService之后会new一个ShunfengService的一个实例(找一家顺丰门店),找到之后把服务注入给小米公司的sellServicesellService就跑到那家顺丰门店填送货单(sendProduct方法)把手机送给客户了。

各位看官应该能想出更好的比喻,欢迎交流。如果有不妥之处欢迎指正。

相关推荐:

AngularJS 依赖注入解析

AngularJS中的依赖注入

30行代码让你理解angular依赖注入:angular 依赖注入原理

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

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.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

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

Les 5 derniers tutoriels Angularjs en 2022, de l'entrée à la maîtrise Les 5 derniers tutoriels Angularjs en 2022, de l'entrée à la maîtrise Jun 15, 2017 pm 05:50 PM

Javascript est un langage tout à fait unique. Il est unique en termes d'organisation du code, de paradigme de programmation du code et de théorie orientée objet. La question de savoir si Javascript est un langage orienté objet a été débattue depuis un certain temps. Il y a évidemment une réponse depuis longtemps. Cependant, même si Javascript est dominant depuis vingt ans, si vous souhaitez comprendre les frameworks populaires tels que jQuery, Angularjs et même React, il suffit de regarder le « Black Horse Cloud Classroom JavaScript Advanced Framework ». Tutoriel vidéo de conception".

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.

Utilisez PHP et AngularJS pour créer un site Web réactif afin d'offrir une expérience utilisateur de haute qualité Utilisez PHP et AngularJS pour créer un site Web réactif afin d'offrir une expérience utilisateur de haute qualité Jun 27, 2023 pm 07:37 PM

À l’ère de l’information d’aujourd’hui, les sites Web sont devenus un outil important permettant aux individus d’obtenir des informations et de communiquer. Un site Web réactif peut s’adapter à divers appareils et offrir aux utilisateurs une expérience de haute qualité, ce qui est devenu un point chaud dans le développement de sites Web modernes. Cet article expliquera comment utiliser PHP et AngularJS pour créer un site Web réactif afin d'offrir une expérience utilisateur de haute qualité. Introduction à PHP PHP est un langage de programmation open source côté serveur idéal pour le développement Web. PHP présente de nombreux avantages, tels que la facilité d'apprentissage, la multiplateforme, la riche bibliothèque d'outils et l'efficacité du développement.

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.

See all articles