国产探花免费观看_亚洲丰满少妇自慰呻吟_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ā)表
主站蜘蛛池模板: 三门县| 麻阳| 赞皇县| 安义县| 都匀市| 湄潭县| 伊通| 莱西市| 措美县| 临洮县| 三河市| 明溪县| 湖南省| 灌阳县| 县级市| 句容市| 杭锦后旗| 德庆县| 灵宝市| 集贤县| 镇远县| 沽源县| 迭部县| 进贤县| 潼南县| 会理县| 乐亭县| 班戈县| 剑河县| 黑水县| 浦县| 静安区| 赤壁市| 额济纳旗| 吉木萨尔县| 开封县| 区。| 江西省| 布拖县| 延安市| 新闻|