位置: 编程技术 - 正文

详解AngularJS的通信机制(angularjs2)

编辑:rootadmin

推荐整理分享详解AngularJS的通信机制(angularjs2),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:angularjs constant,angular.json详解,angular.js,angular jsx,angularjs2,angular.js,angularjs constant,angularjs constant,内容如对您有帮助,希望把文章链接给更多的朋友!

现在几乎满世界的人都在问! 外面有人么&#; 这里是 USS AngularJS, 我们遇到麻烦了,我们的服务讲得是克灵贡语(Klingon) 而我们的控制器不能同它们的Ferengi 指令通信了. 有人能帮助我们么!

我已经不知道有多少次遇到这种有关什么才是AngularJS里面的组件通信的最佳方式这样的问题了. 很多时候答案都会是为此使用 $rootScope 对象去向任何想要收听的人广播$broadcast出一条消息. 然而,那还真不是做这件事的最佳方式. 组件之间广播消息意味着它们需要多少知道一些其它组件编码的细节,这样就限制了它们的模块化和重用.

本文我就将展示如何为AngularJS中的内部组件通信使用发布/订阅模式.

AngularJS 有多种方式可供你用于组件之间的通信,而最常使用的方法却需要你知道太多有关那些组件如何通信的细节,这样就增加了组件之间的耦合度,并降低了它们的模块性和内聚程度. 这样也就使得你的组件很难在其它应用程序中重用.

通过使用发布/订阅设计模式,我们可以降低组件之间的耦合度,并将它们的之间通信的细节封装起来. 这将能帮助增加你组件的模块化程度,可测试性以及可重用性.

我将会描述的发布/订阅模式实现由 Eric Burley, @eburley 在它的帖子angularjs.org 观察, 有关发布订阅模式.. 中推荐过。

我所描述的示例应用程序,会向你展示你可以将发布/订阅模式如何运用于内部控制器通信以及控制器的服务通信. 你可以在GitHub上我的资源库 angularjs-pubsub 下面找到源代码. 首先我们需要一条通信管道

首先我们来讲讲用于处理发布和订阅信息的服务。我定义了一个服务接口,提供了发布和订阅信息的方法,我们可以用它来处理我们想要用来交换的信息。

在下面的代码中,我定义了两个内部信息; _EDIT_DATA_, 用来表示我们需要编辑跟随信息传过来的数据,和 _DATA_UPDATED_, 用来表示我们的数据已经被改变。这些都是定义在内部的,用户没办法访问到它们的,这样有助于隐藏具体实现。

而对于每条信息,有两个方法; 一个用来发布信息推送给订阅者,另一个可以让订阅者注册一个回调方法,当接收到信息的时候,这个方法就会被调用。

用来向订阅者发布信息方法是 editData,在第 9 行,还有 dataUpated,在第 行。它们通过 $rootScope.$broadcast 方法向待处理事件推送私有通知。

详解AngularJS的通信机制(angularjs2)

用来注册事件的方法,通过 $scope.$on 建立监听,当接收到广播的消息之后,就会轮流执行那些被订阅者注册到服务上的事件。同时,由于订阅者需要自己的 scope 作为参数传过来,我们可以用它来执行监听的信息,从而避免了维护监听者列表这些复杂的处理。注册事件的方法是 onEditData,在 行,还有 onDataUpdated 在 行。

为了隐藏实现细节,我用了 Revealing Module (揭示模块:好丑的名字)模式,只返回那些我希望让用户使用的方法。

发布消息

发布消息很简单,首先我们需要在我们的控制器里为 requestNotificationChannel 引入一些依赖. 你可以在下面dataService的定义第二行看到这个. 当事件发生时,如果需要向需要了解有变化发生的其它对象发送信号, 你只需要调用requestNotificationChannel上恰当的通知方法就可以了. 如果你注意到了dataService的 saveHop, deleteHop 和 addHop 方法, 你就会看到它们都调用了 requestNotificationChannel 上的dataUpdated方法, 这个方法将会给侦听器发送信号,侦听器则已经用 onDataUpdated 方法注册过了.

接收事件通知

从 requestNotificationChannel 接收事件通知也很简单,额外的我们只需要回调处理器来在消息被发送时使用通知来做一些自己的处理. 我们将再次需要添加一些依赖到面向我们的控制器、服务以及指令的 requestNotificationChannel 上, 你可以在下面代码的第二行中看到这些. 接下来我们需要定义一个事件回调处理器来对事件通知做出回应,你可以在下面的第五行代码中看到. 然后我们需要通过调用 onDataUpdated 方法来吧我们的回调处理器注册到requestNotificationChannel,并传入来自控制器和回调处理器的范围, 我们在第9行代码中做了这些事情.

用于控制器通信的控制器

我们也可以将 the requestNotificationChannel 用于控制器间的通信. 我们只需要有一个控制器扮演发布者的角色,而另外一个控制器扮演订阅者的角色就行了. 如果你观察到前段代码第行view1-controller的onEdit方法,你会看到它发送了一个editData消息,消息包含需要使用 requestNotificationChannel 编辑的项. 下面的 view2-controller 从第5行到第9行将它的 onEditDataHandler 用 requestNotificationChannel 进行了注册. 如此无论何时view1-controller一旦发送editData消息,带上要修改的项,view2-controller都会受到editData消息的通知,获得该项并将其更新到它的模型.

写一个好的接口文档

有一件事情可能会被忽略,我们在组件间用了通信接口,而这些接口,它们需要一个好的文档来说明应当如何使用。上面的例子中,如果没有文档,用户肯定不会知道 onEditData 会给回调函数传一个待编辑数据。所以当你开始用这个模式,用好的技巧在于,给方法写注释文档,以确保通知服务明确知道发生了什么事情。总结

好了,我们探讨了如何在你的 AngularJS 应用中使用订阅/发布模式来实现模块间通信。该模式可以让你的模块从内部消息解耦,更便于复用。你甚至可以把模块之间的通信全部替换成订阅/发布模式。尤其当你的服务中有很多异步请求,以及你希望把数据缓存在服务中,从而减少和服务器通信的时候,这种模式相当有效。

我希望这对你有所帮助,你可以在我的 GitHub 仓库 angularjs-pubsub 下找到例子的代码。

在AngularJS应用中实现一些动画效果的代码 在Angular当中,CSS和JavaScript之间唯一的区别就是它们的定义。没有什么区别妨碍到被定义的动画被使用。首先,我们需要加载ngAnimate模块到我们应用的roo

3个可以改善用户体验的AngularJS指令介绍 1.头像图片为了在你的应用中展示头像图片,你需要使用用户的电子邮件地址,将地址转换为小写并使用md5加密该字符串。所以聪明的做法是使用指令来

深入讲解AngularJS中的自定义指令的使用 AngularJS的自定义指令,就是你自己的指令,加上编译器编译DOM时运行的原生核心函数。这可能很难理解。现在,假设我们想在应用中不同页面复用一些

标签: angularjs2

本文链接地址:https://www.jiuchutong.com/biancheng/380430.html 转载请保留说明!

上一篇:浅析AngularJS中的生命周期和延迟处理(angular.js)

下一篇:在AngularJS应用中实现一些动画效果的代码(angularjs2)

  • 印花税申报表计税依据怎么填
  • 增值税专用发票使用规定 最新
  • 建筑行业有哪种职业
  • 应付账款超过三年未付
  • 政府回购土地免税政策
  • 印花税的计税依据怎么算公式
  • 收到租赁费发票的账务处理
  • 没有签订购销合同的协议
  • 债券折价发行的会计分录
  • 个人挂靠利润如何提取
  • 资本公积是企业所得税吗
  • 法院案件受理费计算器
  • 税控盘减免税有时间限制吗?
  • 信用证保证金是什么意思
  • 员工拿发票报销可以公转私吗
  • 公司牌车还款从哪里扣款
  • 税收优惠包括哪三个方面的内容
  • 增值税抵扣主要用于哪些税收?
  • 2017年一般纳税人增值税优惠
  • 取得抵债房产的涉税风险,你清楚吗?
  • 融资租赁和融资性售后回租的区别
  • 物业水费电费
  • 应收账款周转次数计算方法
  • 考后审核是什么时候
  • deepin阻止关机
  • win11虚拟键盘怎么调出来
  • 收到上年度企业所得税退税款
  • 进项票与实际支出金额不符
  • php字符串函数大全
  • 母公司向子公司注入资产
  • 生产车间报表表格图片
  • w10如何删除微软拼音
  • 会计中的计算公式
  • 源码阅读技巧
  • 跨年的材料票可以抵扣吗
  • html转化成图片
  • egi脑电数据处理
  • 已申报未导入是什么情况
  • 企业提取盈余公积属于什么会计科目
  • 营业外收支的账户是什么
  • 手机做h5
  • 收购企业怎么做账
  • 什么叫做印花??
  • ibps对公提回贷记有什么影响
  • 委托开发费用
  • 发票拿到了怎样作废
  • 其他应收款对应的预算会计
  • 调整以前年度的费用怎么做
  • 物业公司付电业费合法吗
  • 年报审计调整
  • 代开专票是指?
  • 没有发票的费用怎么做凭证
  • 新手会计做账怎么做账
  • 什么叫建账
  • mysql5.7.17安装
  • win10和os x el capitan分屏操作对比视频
  • Windows时间同步时出错该怎么解决?
  • 怎么在windows
  • winxp安卓
  • 苹果官网
  • win10开机绿色
  • linux查看sh
  • win8系统停止服务
  • hosts文件win10
  • js时间日期
  • quick3.3 UIListview扩展应用
  • jquery网页设计
  • js如何引用
  • linux sar文件路径
  • 获取linux命令执行结果
  • Linux中获取某个进程的系统调用以及参数(故障排查案例)
  • js window.open如何带参数
  • python如何查询函数用法
  • Javascript Global对象
  • 果断收藏9个Javascript代码高亮脚本
  • c# addin
  • android开发从入门到精通(项目案例版)
  • 深圳个人税收完税证明网上打印
  • 销售土地使用权的税率
  • 从印度往中国邮寄药品
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设