這篇文章主要介紹了Angularjs實作控制器之間通訊方式,結合實例形式總結分析了AngularJS控制器常用通訊方式及相關操作注意事項,需要的朋友可以參考下
本文實例講述了Angularjs實作控制器之間通訊方式。分享給大家供大家參考,具體如下:
利用angularjs開發專案中,控制器之間的通信,例如參數的傳遞,資料的傳遞,都是比較常見的。控制器之間的通信,顯得特別重要。常見的方式有以下兩種:一、angular服務的方式;二、基於事件廣播的方式;另外,還有基於作用域繼承的方式。以下先說一下前兩種方式:
一、基於angular服務的方式:
在angular中服務是一個單例,所以在服務中產生一個對象,該對象就可以利用依賴注入的方式在所有的控制器中共享。參考以下例子,在一個控制器修改了服務物件的值,在另一個控制器中取得到修改後的值:
var app = angular.module('myApp', []); app.factory('Myservice', function(){ return {}; }); //定义服务 app.controller('Ctrltest1', function($scope, 'Myservice') { $scope.change = function() { Myservice.name = $scope.test; //在第一个控制器中为服务对象赋值 }; }); app.controller('Ctrltst2', function($scope, 'Myservice') { $scope.add = function() { $scope.name = Myservice.name; //将第一个控制器中为服务对象赋的值传给第二个控制器 }; });
<p ng-controller='Ctrltest1'> <input type="text" ng-model="test" /> <p ng-click="change()">click me</p> </p> <p ng-controller='Ctrltest2'> <p ng-click="add()">my name {{name}}</p> </p>
二、基於事件廣播的方式
基於事件廣播,需要用到$emit()
、$broadcaset()
和$emit()
這三個方法。
1. 向父作用域層次結構發出自訂事件:使用$emit()
方法,scope.$emit(name,[args,...])
附註:name是事件名,args 是0個或多個參數。
應用程式場景:用於子頁面控制器傳送參數給父頁面的控制器。
2. 向子作用域層次結構廣播自訂事件:
應用程式場景:用於父頁面控制器向子頁面的控制器傳遞參數或同級控制器之間傳遞參數。
使用$broadcaset()
方法,$scope.$broadcaset(name,[args,...])
註:name是事件名,args 是0個或多個參數.
3. 使用偵聽器處理自訂事件
為了處理發出或廣播的事件,可以使用$on()
方法。 $on()
方法將使用下面的語法:
$scope.$on(name,listener)
附註: name 是將要偵聽的事件的名字,listener參數是一個函數,它將接受事件作為第一個參數,接受$emit()
或$broadcaset()
方法傳遞的其他所有參數作為隨後的參數。 $on()
方法主要用於監聽$emit()
和$broadcaset()
方法中事件的變化,例如這兩個方法中如果有變數改變,$on()方法將會取得到該變數的改變。
參考以下例子,在一個控制器修改了變數的值,在另一個控制器中會偵聽到修改後的值,並根據修改後的值,做出回應。
app.controller('versiontaskCtrl', function WriteTestcaseCtrl($scope, $cookies, $rootScope, $modal, $stateParams, ui, searchVariable, currentuserversions,) { $scope.taskId = $cookies['edit_taskId']; $scope.versionid = parseInt($cookies['edit_versionId']); $scope.versionName = $cookies['edit_versionName']; $scope.version = $scope.versionid; getuserversions = function () { currentuserversions.get(function (res) { $scope.versions = res; }); }; reload = function () { getuserversions(); }; $scope.changeVersionid = function (v) { console.log(v); $scope.$broadcast('versionidChange', $scope.versionid); //向其他控制器广播$scope.versionid值的变化。 }; reload(); });
第二個控制器中監聽第一個控制器中的廣播事件:
app.controller('SchemeTaskEditableRowCtrl', function ($scope, $rootScope, $cookies, $filter, $http, $window, $stateParams, basetasksService, schemetasksService, UserService) { $scope.taskId = $cookies['edit_taskId']; $scope.versionid = $cookies['edit_versionId']; $scope.version = $scope.versionid; var userid = $rootScope.user.userid; $scope.schemetask = []; $scope.basetask = []; $scope.result = []; $scope.$on('versionidChange', function (event, versionid) { $scope.versionid = versionid; //监听到$scope.versionid值的变化。然后调用 $scope.schemeTask()和$scope.getUsers()这两个方法 $scope.schemeTask(); $scope.getUsers(); }); $scope.schemeTask = function () { $scope.tasks = []; $scope.schemetask = []; schemetasksService.get({version: $scope.versionid}, function (res) { $scope.schemetask_collection = res.results; //console.log($scope.schemetask_collection); $scope.schemetask_displayed = [].concat($scope.schemetask_collection); var i = 1; angular.forEach($scope.schemetask_collection, function (item) { item['director'] = "app.writetestitem" + "({taskid:" + item.id + "})"; item['number'] = i; i++; $scope.schemetask.push(item); }); $scope.tasks = $scope.schemetask; }); }; $scope.getUsers = function () { UserService.get(function (res) { $scope.users = res.results; $scope.usersDisplayed = [].concat($scope.users); $scope.itemArray = []; $scope.userArray = []; $scope.names = []; angular.forEach($scope.users, function (item) { $scope.itemArray.push(item); $scope.userArray.push(item.name + item.number); var itemname = {'name': item.name, 'number': item.number}; $scope.names.push(itemname); }); $scope.selected = $scope.users; }); }; });
上面是我整理給大家的,希望今後對大家有幫助。
相關文章:
Jquery具體實例介紹AJAX何時用,AJAX應該在什麼地方用
初步了解JavaScript,Ajax,jQuery,並比較三者關係
以上是Angularjs實作控制器之間通訊方式實例總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!