最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Angularjs的Controller间通信机制实例分析

来源:动视网 责编:小采 时间:2020-11-27 20:28:51
文档

Angularjs的Controller间通信机制实例分析

Angularjs的Controller间通信机制实例分析:本文实例讲述了Angularjs的Controller间通信机制。分享给大家供大家参考,具体如下:在Angularjs开发一些经验总结中提到我们需要按照业务区分angular controller,避免过大无所不能的上帝controller,我们把controller分离开了,但是有时候我们需要
推荐度:
导读Angularjs的Controller间通信机制实例分析:本文实例讲述了Angularjs的Controller间通信机制。分享给大家供大家参考,具体如下:在Angularjs开发一些经验总结中提到我们需要按照业务区分angular controller,避免过大无所不能的上帝controller,我们把controller分离开了,但是有时候我们需要


本文实例讲述了Angularjs的Controller间通信机制。分享给大家供大家参考,具体如下:

在Angularjs开发一些经验总结中提到我们需要按照业务区分angular controller,避免过大无所不能的上帝controller,我们把controller分离开了,但是有时候我们需要在controller中通信,一般为比较简单的通信机制,告诉同伴controller我的某个你所关心的东西改变了,怎么办?如果你是一个javascript程序员你会很自然的想到异步回调响应式通信—事件机制(或消息机制)。对,这就是angularjs解决controller之间通信的机制,所推荐的唯一方式,简而言之这就是angular way。

Angularjs为在scope中为我们提供了冒泡和隧道机制,$broadcast会把事件广播给所有子controller,而$emit则会将事件冒泡传递给父controller,$on则是angularjs的事件注册函数,有了这一些我们就能很快的以angularjs的方式去解决angularjs controller之间的通信,代码如下:

View:

<div ng-app="app" ng-controller="parentCtr">
 <div ng-controller="childCtr1">name :
 <input ng-model="name" type="text" ng-change="change(name);" />
 </div>
 <div ng-controller="childCtr2">Ctr1 name:
 <input ng-model="ctr1Name" />
 </div>
</div>

Controller:

angular.module("app", []).controller("parentCtr",
function ($scope) {
 $scope.$on("Ctr1NameChange",
 function (event, msg) {
 console.log("parent", msg);
 $scope.$broadcast("Ctr1NameChangeFromParrent", msg);
 });
}).controller("childCtr1", function ($scope) {
 $scope.change = function (name) {
 console.log("childCtr1", name);
 $scope.$emit("Ctr1NameChange", name);
 };
}).controller("childCtr2", function ($scope) {
 $scope.$on("Ctr1NameChangeFromParrent",
 function (event, msg) {
 console.log("childCtr2", msg);
 $scope.ctr1Name = msg;
 });
});

这里childCtr1的name改变会以冒泡传递给父controller,而父controller会对事件包装在广播给所有子controller,而childCtr2则注册了change事件,并改变自己。注意父controller在广播时候一定要改变事件name。

jsfiddle链接:http://jsfiddle.net/whitewolf/5JBA7/15/

希望本文所述对大家AngularJS程序设计有所帮助。

文档

Angularjs的Controller间通信机制实例分析

Angularjs的Controller间通信机制实例分析:本文实例讲述了Angularjs的Controller间通信机制。分享给大家供大家参考,具体如下:在Angularjs开发一些经验总结中提到我们需要按照业务区分angular controller,避免过大无所不能的上帝controller,我们把controller分离开了,但是有时候我们需要
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top