詳解angularjs中如何實現(xiàn)控制器和指令之間交互
如果我們具有下面的DOM結構:
<div ng-controller="MyCtrl"> <loader>滑動加載</loader> </div>
同時我們的控制器具有如下的簽名:
var myModule = angular.module("MyModule", []); //首先定義一個模塊并在模塊下掛載控制器,第二個參數(shù)為一個數(shù)組,其中函數(shù)前面的參數(shù)都是會被注入到函數(shù)形參上面的 myModule.controller('MyCtrl', ['$scope', function($scope){ $scope.loadData=function(){ console.log("加載數(shù)據(jù)中..."); } }]);
同時指令的簽名如下:
myModule.directive("loader", function() { return { restrict:"AE",//Element,Attribute link:function(scope,element,attrs){ element.bind('mouseenter', function(event) { //scope.loadData(); // scope.$apply("loadData()"); // 注意這里的坑,howToLoad會被轉換成小寫的howtoload }); } } });
這時候我們的指令通過scope.loadData或者scope.$apply就可以完成對控制器的調用了。但是如果我們具有兩個控制器呢?而且兩個控制器中$scope中方法是不同的?
var myModule = angular.module("MyModule", []); //首先定義一個模塊并在模塊下掛載控制器,第二個參數(shù)為一個數(shù)組,其中函數(shù)前面的參數(shù)都是會被注入到函數(shù)形參上面的 myModule.controller('MyCtrl', ['$scope', function($scope){ $scope.loadData=function(){ console.log("加載數(shù)據(jù)中..."); } }]); myModule.controller('MyCtrl2', ['$scope', function($scope){ $scope.loadData2=function(){ console.log("加載數(shù)據(jù)中...22222"); } }]);
這時候在我們的指令中如何調用方法呢,按照上面的方式的話那么那么就會面臨問題:MyCtrl2沒有我們的loadData,而只有l(wèi)oadData2!這時候我們就需要使用后面的指令自定義屬性了!
我們定義了兩個controller控制器,分別為MyCtrl,MyCtrl2,這兩個控制器都使用了我們自己定義的指令load:
<!doctype html> <html ng-app="MyModule"> <head> <meta charset="utf-8"> </head> <body> <!--第一個控制器MyCtrl--> <div ng-controller="MyCtrl"> <loader howToLoad="loadData()">滑動加載</loader> </div> <!--第二個控制器MyCtrl2--> <div ng-controller="MyCtrl2"> <loader howToLoad="loadData2()">滑動加載</loader> </div> </body> <script src="framework/angular-1.3.0.14/angular.js"></script> <script src="Directive&Controller.js"></script> </html>
我們自定義了Controller代碼如下:
var myModule = angular.module("MyModule", []); //首先定義一個模塊并在模塊下掛載控制器,第二個參數(shù)為一個數(shù)組,其中函數(shù)前面的參數(shù)都是會被注入到函數(shù)形參上面的 myModule.controller('MyCtrl', ['$scope', function($scope){ $scope.loadData=function(){ console.log("加載數(shù)據(jù)中..."); } }]); myModule.controller('MyCtrl2', ['$scope', function($scope){ $scope.loadData2=function(){ console.log("加載數(shù)據(jù)中...22222"); } }]); //在模塊下掛載一個loader指令 myModule.directive("loader", function() { return { restrict:"AE",//Element,Attribute link:function(scope,element,attrs){ element.bind('mouseenter', function(event) { //scope.loadData(); // scope.$apply("loadData()"); // 注意這里的坑,howToLoad會被轉換成小寫的howtoload // scope.$apply(attrs.howtoload); //其中scope為POJO,但是有一系列的工具方法如$watch,$apply等 }); } } });
很顯然這里有兩個控制器,分別為MyCtrl和MyCtrl2,我們的指令如何知道調用那一個Controller?這時候我們就需要為我們的指令指定不同的屬性,用這個屬性來判斷不同的controller調用,這樣我們的指令就可以在不同的controller中調用了!
總結:之所以定義指令就是為了復用,為了讓指令和不同的控制器進行交互就會為指令定義不同的配置項,這就是指令和控制器進行數(shù)據(jù)交互的原理之所在!
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- 深入講解AngularJS中的自定義指令的使用
- 詳解AngularJS中自定義指令的使用
- AngularJS創(chuàng)建自定義指令的方法詳解
- AngularJS使用自定義指令替代ng-repeat的方法
- Angularjs自定義指令實現(xiàn)三級聯(lián)動 選擇地理位置
- Angularjs使用directive自定義指令實現(xiàn)attribute繼承的方法詳解
- angularjs 表單密碼驗證自定義指令實現(xiàn)代碼
- AngularJs中 ng-repeat指令中實現(xiàn)含有自定義指令的動態(tài)html的方法
- AngularJS自定義指令實現(xiàn)面包屑功能完整實例
- AngularJS自定義指令之復制指令實現(xiàn)方法
- AngularJS指令與控制器之間的交互功能示例
- AngularJS實現(xiàn)自定義指令與控制器數(shù)據(jù)交互的方法示例
相關文章
Angular2仿照微信UI實現(xiàn)9張圖片上傳和預覽的示例代碼
本篇文章主要介紹了Angular2仿照微信UI實現(xiàn)9張圖片上傳和預覽的示例代碼,非常具有實用價值,需要的朋友可以參考下2017-10-10Angular 4根據(jù)組件名稱動態(tài)創(chuàng)建出組件的方法教程
組件是我們在學習angular中必不可少的一部分,下面這篇文章主要給大家介紹了關于Angular 4如何根據(jù)組件名稱動態(tài)創(chuàng)建出組件的相關資料,文中通過圖文與示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面來一起看看吧。2017-11-11在Angular項目使用socket.io實現(xiàn)通信的方法
這篇文章主要介紹了在Angular項目使用socket.io實現(xiàn)通信的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01AngularJS+Node.js實現(xiàn)在線聊天室
隨著互聯(lián)網(wǎng)和信息技術的發(fā)展,如何快速構建高效、強大的動態(tài)網(wǎng)站成為很多人研究的熱點。該文將結合AngularJS和Node.js構建一個在線聊天室,體現(xiàn)AngularJs和Node.js整合的優(yōu)點。2015-08-08