欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解angularjs中如何實(shí)現(xiàn)控制器和指令之間交互

 更新時(shí)間:2017年05月31日 14:07:52   作者:liangklfang  
本篇文章主要介紹了詳解angularjs中如何實(shí)現(xiàn)控制器和指令之間交互,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

如果我們具有下面的DOM結(jié)構(gòu):

  <div ng-controller="MyCtrl"> 
   <loader>滑動(dòng)加載</loader> 
</div> 

同時(shí)我們的控制器具有如下的簽名:

var myModule = angular.module("MyModule", []); 
//首先定義一個(gè)模塊并在模塊下掛載控制器,第二個(gè)參數(shù)為一個(gè)數(shù)組,其中函數(shù)前面的參數(shù)都是會(huì)被注入到函數(shù)形參上面的 
myModule.controller('MyCtrl', ['$scope', function($scope){ 
  $scope.loadData=function(){ 
    console.log("加載數(shù)據(jù)中..."); 
  } 
}]); 

同時(shí)指令的簽名如下:

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會(huì)被轉(zhuǎn)換成小寫(xiě)的howtoload 
      }); 
    } 
  }  
}); 

這時(shí)候我們的指令通過(guò)scope.loadData或者scope.$apply就可以完成對(duì)控制器的調(diào)用了。但是如果我們具有兩個(gè)控制器呢?而且兩個(gè)控制器中$scope中方法是不同的?

var myModule = angular.module("MyModule", []); 
//首先定義一個(gè)模塊并在模塊下掛載控制器,第二個(gè)參數(shù)為一個(gè)數(shù)組,其中函數(shù)前面的參數(shù)都是會(huì)被注入到函數(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"); 
  } 
}]); 

這時(shí)候在我們的指令中如何調(diào)用方法呢,按照上面的方式的話(huà)那么那么就會(huì)面臨問(wèn)題:MyCtrl2沒(méi)有我們的loadData,而只有l(wèi)oadData2!這時(shí)候我們就需要使用后面的指令自定義屬性了!

我們定義了兩個(gè)controller控制器,分別為MyCtrl,MyCtrl2,這兩個(gè)控制器都使用了我們自己定義的指令load:

<!doctype html> 
<html ng-app="MyModule"> 
  <head> 
    <meta charset="utf-8"> 
  </head> 
  <body> 
  <!--第一個(gè)控制器MyCtrl--> 
    <div ng-controller="MyCtrl"> 
      <loader howToLoad="loadData()">滑動(dòng)加載</loader> 
    </div> 
    <!--第二個(gè)控制器MyCtrl2--> 
    <div ng-controller="MyCtrl2"> 
      <loader howToLoad="loadData2()">滑動(dòng)加載</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", []); 
//首先定義一個(gè)模塊并在模塊下掛載控制器,第二個(gè)參數(shù)為一個(gè)數(shù)組,其中函數(shù)前面的參數(shù)都是會(huì)被注入到函數(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"); 
  } 
}]); 
//在模塊下掛載一個(gè)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會(huì)被轉(zhuǎn)換成小寫(xiě)的howtoload 
        // scope.$apply(attrs.howtoload); 
        //其中scope為POJO,但是有一系列的工具方法如$watch,$apply等 
      }); 
    } 
  }  
}); 

很顯然這里有兩個(gè)控制器,分別為MyCtrl和MyCtrl2,我們的指令如何知道調(diào)用那一個(gè)Controller?這時(shí)候我們就需要為我們的指令指定不同的屬性,用這個(gè)屬性來(lái)判斷不同的controller調(diào)用,這樣我們的指令就可以在不同的controller中調(diào)用了!

總結(jié):之所以定義指令就是為了復(fù)用,為了讓指令和不同的控制器進(jìn)行交互就會(huì)為指令定義不同的配置項(xiàng),這就是指令和控制器進(jìn)行數(shù)據(jù)交互的原理之所在!

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Angular PWA使用的Demo示例

    Angular PWA使用的Demo示例

    這篇文章主要介紹了Angular PWA使用的Demo示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • Angular2仿照微信UI實(shí)現(xiàn)9張圖片上傳和預(yù)覽的示例代碼

    Angular2仿照微信UI實(shí)現(xiàn)9張圖片上傳和預(yù)覽的示例代碼

    本篇文章主要介紹了Angular2仿照微信UI實(shí)現(xiàn)9張圖片上傳和預(yù)覽的示例代碼,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2017-10-10
  • Angular 4根據(jù)組件名稱(chēng)動(dòng)態(tài)創(chuàng)建出組件的方法教程

    Angular 4根據(jù)組件名稱(chēng)動(dòng)態(tài)創(chuàng)建出組件的方法教程

    組件是我們?cè)趯W(xué)習(xí)angular中必不可少的一部分,下面這篇文章主要給大家介紹了關(guān)于Angular 4如何根據(jù)組件名稱(chēng)動(dòng)態(tài)創(chuàng)建出組件的相關(guān)資料,文中通過(guò)圖文與示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-11-11
  • angularJS 中$attrs方法使用指南

    angularJS 中$attrs方法使用指南

    這篇文章主要介紹了angularJS 中$attrs方法使用指南,需要的朋友可以參考下
    2015-02-02
  • 在Angular項(xiàng)目使用socket.io實(shí)現(xiàn)通信的方法

    在Angular項(xiàng)目使用socket.io實(shí)現(xiàn)通信的方法

    這篇文章主要介紹了在Angular項(xiàng)目使用socket.io實(shí)現(xiàn)通信的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • AngularJS+Node.js實(shí)現(xiàn)在線聊天室

    AngularJS+Node.js實(shí)現(xiàn)在線聊天室

    隨著互聯(lián)網(wǎng)和信息技術(shù)的發(fā)展,如何快速構(gòu)建高效、強(qiáng)大的動(dòng)態(tài)網(wǎng)站成為很多人研究的熱點(diǎn)。該文將結(jié)合AngularJS和Node.js構(gòu)建一個(gè)在線聊天室,體現(xiàn)AngularJs和Node.js整合的優(yōu)點(diǎn)。
    2015-08-08
  • AngularJS過(guò)濾器詳解及示例代碼

    AngularJS過(guò)濾器詳解及示例代碼

    本文主要介紹AngularJS過(guò)濾器,這里整理了詳細(xì)的資料和提供了示例代碼及實(shí)例效果圖,有興趣的小伙伴可以參考下
    2016-08-08
  • AngularJS 整理一些優(yōu)化的小技巧

    AngularJS 整理一些優(yōu)化的小技巧

    本文主要介紹AngularJS 一些優(yōu)化上的小技巧,這里整理了幾種方法供大家參考,有興趣的小伙伴可以參考下
    2016-08-08
  • AngularJS中scope的綁定策略實(shí)例分析

    AngularJS中scope的綁定策略實(shí)例分析

    這篇文章主要介紹了AngularJS中scope的綁定策略,結(jié)合實(shí)例形式簡(jiǎn)單分析了AngularJS scope的三種綁定模式的使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2017-10-10
  • Angular2學(xué)習(xí)教程之ng中變更檢測(cè)問(wèn)題詳解

    Angular2學(xué)習(xí)教程之ng中變更檢測(cè)問(wèn)題詳解

    這篇文章主要給大家介紹了Angular2學(xué)習(xí)教程之ng中變更檢測(cè)問(wèn)題的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-05-05

最新評(píng)論