位置: 编程技术 - 正文

详解AngularJS的通信机制(angularjs2)

发布时间:2024-02-27

推荐整理分享详解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)

  • 总公司是小规模分公司是一般纳税人
  • 管理费用中的办公费占比是多少
  • 发票抬头开个人可以吗
  • 公司组织出去旅游主持词
  • 教育培训行业成本怎么结转
  • 股东之间股权转让流程
  • 收回已转销的坏账在借方还是贷方
  • 预付账款转出分录
  • 在公司发现问题该说吗
  • 固定资产折旧税务处理
  • 生活垃圾处理项目基础金融产品包括
  • 公司注销前怎么平账才不用交税
  • windows11怎么设置默认应用
  • windows10如何关闭左下角的搜索
  • 如何进行网速测试设置
  • win10怎么设置硬盘为第一启动项
  • .exe是什么程序
  • 未签订租赁合同租金如何确定
  • 评价指标mae
  • json与json字符串
  • framework4.0怎么打开
  • php如何防止后门
  • 加油费属于什么费用类别的
  • 个税专项扣除中赡养老人
  • 小规模纳税人减免增值税会计处理
  • php一个文件搞定两个文件
  • vue-bus
  • setdo指令
  • 在php中,字符串有哪些表示形式
  • timestamp 0
  • 车船税每年都要多少钱
  • 保险费支出是什么意思
  • 银行转账回执单掉了
  • 网上免费学电脑
  • 在阿里云的云主机之间怎么通信
  • 长期待摊费用账务处理包括哪两部分
  • 小规模纳税人代销商品增值税如何计算
  • 管理费用的核算内容主要包括哪些
  • 幼儿园伙食账目
  • 一般纳税人销售自己使用过的汽车
  • 小规模纳税人应纳税额减征额怎么算
  • 运输公司内账会计每天需要做什么
  • 退去年的销售账务如何处理
  • 公交公司如何做好精细化管理
  • 企业变更地址需要几天
  • 审计库存现金盘点表
  • 京东提现一般多久到账
  • 单位购买金税盘账务处理
  • 支付系统安装
  • 工程预缴税款流程
  • 销售收入指开票金额吗
  • 应收账款多收了退回怎么做账
  • 可供出售金融资产是指什么
  • 其他综合收益包括留存收益吗
  • 建账的过程包括哪些内容
  • Sqlserver聚集索引和非聚集索引的区别
  • win 10如何安装
  • linux命令ethtool
  • win8 怎么样
  • mac怎么连接校园网wifi
  • avgcc32.exe进程是什么文件产生的 avgcc32进程信息查询
  • executor进程
  • smss.exe什么意思
  • window10 不能上网
  • 实例讲解命局与大运流年作用
  • easyui下拉列表
  • node创建服务
  • dos命令怎么写
  • jQuery position() 函数详解以及jQuery中position函数的应用
  • linux特殊符号转义
  • 在jquery中fadein
  • js函数的声明方式
  • html5table
  • javascript如何写操作命令
  • listview报错
  • 解决烧心最快方法
  • 重大税务违法案件一案双查标准
  • 河南热力公司收费标准
  • 工会经费扣除标准2022
  • 跨境电商出口商品结构
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号