首頁 > web前端 > js教程 > 主體

angularjs中如何實作控制器與指令之間互動的實例程式碼

黄舟
發布: 2017-06-01 09:34:42
原創
1037 人瀏覽過

本篇文章主要介紹了詳解angularjs中如何實現控制器和指令之間交互,具有一定的參考價值,感興趣的小夥伴們可以參考一下

如果我們有下面的DOM結構:

  <p ng-controller="MyCtrl"> 
   <loader>滑动加载</loader> 
</p>
登入後複製

同時我們的控制器有如下的簽章:

var myModule = angular.module("MyModule", []); 
//首先定义一个模块并在模块下挂载控制器,第二个参数为一个数组,其中函数前面的参数都是会被注入到函数形参上面的 
myModule.controller(&#39;MyCtrl&#39;, [&#39;$scope&#39;, function($scope){ 
  $scope.loadData=function(){ 
    console.log("加载数据中..."); 
  } 
}]);
登入後複製

同時指令的簽章如下:

myModule.directive("loader", function() { 
  return { 
    restrict:"AE",//Element,Attribute 
    link:function(scope,element,attrs){ 
      element.bind(&#39;mouseenter&#39;, function(event) { 
        //scope.loadData(); 
        // scope.$apply("loadData()"); 
        // 注意这里的坑,howToLoad会被转换成小写的howtoload 
      }); 
    } 
  }  
});
登入後複製

這時候我們的指令透過scope.loadData或scope.$apply就可以完成對控制器的呼叫了。但是如果我們有兩個控制器呢?而且兩個控制器中$scope中方法是不同的?

var myModule = angular.module("MyModule", []); 
//首先定义一个模块并在模块下挂载控制器,第二个参数为一个数组,其中函数前面的参数都是会被注入到函数形参上面的 
myModule.controller(&#39;MyCtrl&#39;, [&#39;$scope&#39;, function($scope){ 
  $scope.loadData=function(){ 
    console.log("加载数据中..."); 
  } 
}]); 
myModule.controller('MyCtrl2', ['$scope', function($scope){ 
  $scope.loadData2=function(){ 
    console.log("加载数据中...22222"); 
  } 
}]);
登入後複製

這時候在我們的指令中如何調用方法呢,按照上面的方式的話那麼就會面臨問題:MyCtrl2沒有我們的loadData,而只有loadData2!這時候我們就需要使用後面的指令自訂屬性了!

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

<!doctype html> 
<html ng-app="MyModule"> 
  <head> 
    <meta charset="utf-8"> 
  </head> 
  <body> 
  <!--第一个控制器MyCtrl--> 
    <p ng-controller="MyCtrl"> 
      <loader howToLoad="loadData()">滑动加载</loader> 
    </p> 
    <!--第二个控制器MyCtrl2--> 
    <p ng-controller="MyCtrl2"> 
      <loader howToLoad="loadData2()">滑动加载</loader> 
    </p> 
  </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", []); 
//首先定义一个模块并在模块下挂载控制器,第二个参数为一个数组,其中函数前面的参数都是会被注入到函数形参上面的 
myModule.controller(&#39;MyCtrl&#39;, [&#39;$scope&#39;, function($scope){ 
  $scope.loadData=function(){ 
    console.log("加载数据中..."); 
  } 
}]); 
myModule.controller('MyCtrl2', ['$scope', function($scope){ 
  $scope.loadData2=function(){ 
    console.log("加载数据中...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中呼叫了!

總結:之所以定義指令就是為了復用,為了讓指令和不同的控制器進行交互就會為指令定義不同的配置項,這就是指令和控制器進行資料互動的原理之所在!

以上是angularjs中如何實作控制器與指令之間互動的實例程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!