ホームページ >ウェブフロントエンド >jsチュートリアル >Angularjsのコントローラー間相互通信機能の詳細説明

Angularjsのコントローラー間相互通信機能の詳細説明

php中世界最好的语言
php中世界最好的语言オリジナル
2018-06-13 14:47:342090ブラウズ

今回はAngularjsのコントローラーの相互通信機能について詳しく解説します。Angularjsでコントローラー同士を通信させる際の注意点は何ですか?実際の事例を見てみましょう。

angularjs 開発プロジェクトでは、パラメーター転送やデータ転送など、コントローラー間の通信が比較的一般的です。コントローラー間の通信は特に重要です。一般的な方法は 2 つあり、1 つ目は angular サービス方法、2 つ目はイベント ブロードキャストに基づく方法、さらにスコープ継承に基づく方法です。まず最初の 2 つのメソッドについて説明しましょう:

1. Angular サービスに基づくメソッド:

Angular では、サービスはシングルトンであるため、サービス内でオブジェクトが生成され、オブジェクトは依存関係注入を使用できます。メソッドはすべてのコントローラーで共有されます。次の例を参照して、1 つのコントローラーでサービス オブジェクトの値を変更し、別のコントローラーで変更された値を取得します。

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=&#39;Ctrltest1&#39;>
  <input type="text" ng-model="test" />
  <p ng-click="change()">click me</p>
</p>
<p ng-controller=&#39;Ctrltest2&#39;>
 <p ng-click="add()">my name {{name}}</p>
</p>

2. イベント ブロードキャストに基づいて

イベント ブロードキャストに基づいて、次を使用する必要があります。 3 つのメソッド $emit()$broadcaset()、および $emit() に移動します。 $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()

1. カスタム イベントを親スコープ階層に送信します: $emit() メソッド、scope.$emit(name,[args,...]) を使用します。

注:

name はイベント名、args は 0 個以上のパラメーターです。

アプリケーションシナリオ:

子ページコントローラーから親ページコントローラーにパラメーターを渡すために使用されます。

2. カスタム イベントをサブスコープ階層にブロードキャストします:

アプリケーション シナリオ:

親ページ コントローラーが子ページ コントローラーにパラメーターを渡す、または兄弟コントローラー間でパラメーターを渡すために使用されます。 $broadcaset() メソッド、$scope.$broadcaset(name,[args,...]) を使用します

🎜注: 🎜name はイベントですname、args は 0 個以上のパラメータです。🎜🎜3. リスナーを使用してカスタム イベントを処理します🎜🎜 発行されたイベントまたはブロードキャスト イベントを処理するには、$on() メソッドを使用できます。 $on() メソッドは次の構文を使用します: 🎜🎜$scope.$on(name,listener)🎜🎜🎜注: 🎜name は、リスナー パラメータはイベントを最初のパラメータとして受け入れる関数であり、他のすべてのパラメータは $emit() または $broadcaset() によって渡されます。 > メソッドを後続のパラメータとして使用します。 $on() メソッドは主に、$emit() メソッドと $broadcaset() メソッドのイベントの変更を監視するために使用されます。これら 2 つのメソッド 変数が変更されると、$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();
});
🎜 2 番目のコントローラーは、最初のコントローラーのブロードキャスト イベントを監視します。 🎜
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;
  });
 };
});
🎜 この記事のケースを読んだ後は、この方法を習得したと思います。さらに興味深い情報については、PHP 中国語 Web サイトの他の関連記事に注目してください。 ! 🎜🎜推奨読書: 🎜🎜🎜HTML文字列をHTMLタグに変換し、🎜🎜🎜🎜🎜jsのnew()で🎜🎜🎜を指すコンストラクターの戻り値を変更する方法

以上がAngularjsのコントローラー間相互通信機能の詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。