国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

詳解Angularjs中的依賴注入

2019-11-20 10:24:02
字體:
供稿:網(wǎng)友

一個(gè)對(duì)象通常有三種方式可以獲得對(duì)其依賴的控制權(quán):

  • 在內(nèi)部創(chuàng)建依賴;
  • 通過全局變量進(jìn)行引用;
  • 在需要的地方通過參數(shù)進(jìn)行傳遞

依賴注入是通過第三種方式實(shí)現(xiàn)的。比如:

function SomeClass(greeter) {this.greeter = greeter;}SomeClass.prototype.greetName = function(name) {this.greeter.greet(name);};

SomeClass能夠在運(yùn)行時(shí)訪問到內(nèi)部的greeter,但它并不關(guān)心如何獲得對(duì)greeter的引用。
為了獲得對(duì)greeter實(shí)例的引用,SomeClass的創(chuàng)建者會(huì)負(fù)責(zé)構(gòu)造其依賴關(guān)系并傳遞進(jìn)去。

基于以上原因,AngularJS使用$injetor(注入器服務(wù))來管理依賴關(guān)系的查詢和實(shí)例化。
事實(shí)上,$injetor負(fù)責(zé)實(shí)例化AngularJS中所有的組件,包括應(yīng)用的模塊、指令和控制器等。

例如下面這段代碼。這是一個(gè)簡單的應(yīng)用,聲明了一個(gè)模塊和一個(gè)控制器:

angular.module('myApp', []).factory('greeter', function() {return {greet: function(msg) {alert(msg);}}}).controller('MyController',function($scope, greeter) {$scope.sayHello = function() {greeter.greet("Hello!");};});

當(dāng)AngularJS實(shí)例化這個(gè)模塊時(shí),會(huì)查找greeter并自然而然地把對(duì)它的引用傳遞進(jìn)去:

<div ng-app="myApp"><div ng-controller="MyController"><button ng-click="sayHello()">Hello</button></div></div>

而在內(nèi)部,AngularJS的處理過程是下面這樣的:

// 使用注入器加載應(yīng)用var injector = angular.injector(['ng', 'myApp']);// 通過注入器加載$controller服務(wù):var $controller = injector.get('$controller');var scope = injector.get('$rootScope').$new();// 加載控制器并傳入一個(gè)作用域,同AngularJS在運(yùn)行時(shí)做的一樣var MyController = $controller('MyController', {$scope: scope})

以上就是本文的全部內(nèi)容,希望本文對(duì)大家學(xué)習(xí)Angularjs依賴注入有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 宜宾县| 永年县| 桐乡市| 靖江市| 友谊县| 巩留县| 通河县| 济南市| 饶平县| 无极县| 博野县| 天台县| 浙江省| 金门县| 澳门| 招远市| 灵武市| 华宁县| 兴安县| 建瓯市| 新和县| 安岳县| 吴忠市| 青阳县| 宁德市| 阜城县| 日土县| 吉首市| 新密市| 沈丘县| 中江县| 郑州市| 河曲县| 淮南市| 张家川| 潜江市| 油尖旺区| 平湖市| 平邑县| 庆城县| 尼玛县|