ホームページ  >  記事  >  ウェブフロントエンド  >  Angularjs を使用すると、コントローラーが相互に通信できるようになります (コードが添付されています)。

Angularjs を使用すると、コントローラーが相互に通信できるようになります (コードが添付されています)。

php中世界最好的语言
php中世界最好的语言オリジナル
2018-05-03 10:57:511151ブラウズ

今回は、コントローラーが相互に通信できるようにするためのAngularjsを紹介します。Angularjsでコントローラーが相互に通信できるようにするための注意事項

を次に示します。一見。

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

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

Angular では、サービスはシングルトンであるため、サービス内でオブジェクトが生成され、オブジェクトは dependency を使用できます。インジェクション

メソッドはすべてのコントローラーで共有されます。次の例を参照して、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. イベント ブロードキャストに基づいて

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

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 サイトの他の関連記事に注目してください。 ! 🎜🎜推奨読書: 🎜🎜🎜jQuery は、入力テキストが指定された行数を超えた場合に省略記号の自動追加を実装します🎜🎜🎜🎜🎜WeChat アプレットはページを共有し、ホームページに戻ります🎜🎜🎜

以上がAngularjs を使用すると、コントローラーが相互に通信できるようになります (コードが添付されています)。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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