位置: 编程技术 - 正文

详解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)

  • 物业公司增值税加计扣除
  • 企业在异地设立的办事处撤销了,人员咋办
  • 一般纳税人改成小规模纳税人
  • 国库券利息收入计入利润总额吗
  • 工会经费支付福利方案
  • 股东归还公司借款,应该记什么科目
  • 企业所得税零申报表怎么填写
  • 存货取得的分录
  • 长期挂账应收账款怎么调
  • 房地产企业老项目增值税
  • 购买方退货的会计处理
  • 不付供应商尾款了怎么清账
  • 年底开发票需要交企业所得税吗?
  • 增值税普通发票和专用发票有什么区别
  • 免税收入的三个条件
  • 平销返利怎么开票入账
  • 税务局退的教育费附加怎么做账
  • 固定资产折旧和累计折旧的区别
  • 升级华为鸿蒙系统怎么样
  • 去掉右键菜单中的快捷键
  • Win10 20H2 KB5001391补丁包更新内容汇总
  • 企业老板机票怎么报销记账
  • 报销旅游门票怎么报销
  • paddle!
  • php数组函数输出《咏雪》里有多少"片"字
  • 乱账怎么调整
  • 增值税税收类型有哪些
  • 阿拉斯给加拉普
  • 进货开了发票也写了购销合同要交印花税吗
  • 施工单位老板
  • jsonp解决跨域问题spring3.0
  • js中的截取字符串
  • php判断手机浏览记录数据
  • 企业所得税纳税人包括哪些类型
  • 收到的赔款,罚款怎么算
  • 手工账结转
  • 帝国cms商城源码
  • c语言printf输出数组
  • 基于sqlite特殊字符转义的实现方法
  • 小规模纳税人成本含税吗
  • 公章变更需要到哪个部门
  • 汽车维修行业工时标准
  • 网上0申报怎么操作步骤
  • 企业做账会计分录流程
  • 简述银行存款对应的业务
  • sqlserver2019配置
  • 开劳务发票需要的资料有哪些?
  • 子公司向母公司交利润 需要纳税吗
  • 工资算营业成本还是管理费用
  • 转出未交增值税年末怎么转平
  • 贴现法付息实际利率
  • 业务招待费扣除标准2023
  • 收银系统入库入错了怎么办
  • 采购商品验收入库的会计分录怎么写
  • 增值税结转到本年利润吗
  • 会计各种凭证的填写示例
  • 应收账款的政策
  • centos邮件服务器
  • iis w3svc
  • vim入门教程
  • linux怎么vi
  • assoc .exe=exefile是什么
  • xp怎么安全模式
  • win8适合打游戏吗
  • windows开始按钮点了没用
  • win8.1安装过程
  • eclipse怎么装插件
  • bootstrap怎么引用
  • 感恩节0
  • bootstrap表单模板
  • python算法简单编程题
  • jquery easy ui
  • 深入浅出nginx实战
  • 关于android工程中的assets目录的正确说法
  • json初学
  • python作用域和命名空间
  • android socket聊天
  • 税务局网上申请开票
  • 土地重置成本价
  • 建筑垃圾清运属于什么应税服务
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设