浅谈angular2子组件的事件传递(任意组件事件传递)


Posted in Javascript onSeptember 30, 2018

angular2子组件的事件传递

angular2有很多组件组成,画面由很多路由,导致事件的传递很“笨拙”,本组的技术负责人发现了任意组件传递事件的这个方法,教会了我,我做个笔记。

项目情况:

画面结构复杂,路由数目偏多,组件数目多,嵌套复杂。业务要求:任何出现人名的地方,点击人名,直接打开和这个人的聊天画面

以前用angular2官网给的烹饪技巧基本解决90%的需求,当然这个如果是用Input,Output也可以,但是那样的话,结构将是混沌状态。

附:angluar2的组件通讯的传送门(anglar2的官网对Safari支持可不太好,真爱生命,请用chrome)

实现

service:

这是重点,相当于一个事件队列,所有注入此service的组件,都可以发起事件,插入到队列中,所有订阅此事件队列的组件都会收到广播。(暂时先用广播这个词吧)

public eventbus: EventEmitter<any> = new EventEmitter<any>();

聊天组件:

constructor( private _workservice:WorkService) {
 // 订阅聊天事件
 this._workservice.eventbus.subscribe(_event => {
  if (_event&&_event.name=='chart') {
  // 所有订阅这个事件的组件都会收到eventbus上的事件触发,相当于广播。
  // 所以使用在事件传递的参数中添加一个name变量来判断这个事件是不是给我的。
   // .........
   // 此处写处理就行了,通过_event取参数
   // .........
  }
  }
 )
 }

发起聊天的组件:

this.workService.eventbus.emit({
  type:3,
  voipAccount:userid
 });
// 注意emit()的参数是json结构。

简单示意

浅谈angular2子组件的事件传递(任意组件事件传递)

以上这篇浅谈angular2子组件的事件传递(任意组件事件传递)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript实现表格排序 编辑 拖拽 缩放
Jan 02 Javascript
JavaScript和jQuery获取input框的绝对位置实现方法
Oct 13 Javascript
利用D3.js实现最简单的柱状图示例代码
Dec 09 Javascript
ES6下React组件的写法示例代码
May 04 Javascript
微信小程序上传图片到服务器实例代码
Nov 07 Javascript
vue-router路由懒加载的实现(解决vue项目首次加载慢)
Aug 28 Javascript
原生JS forEach()和map()遍历的区别、兼容写法及jQuery $.each、$.map遍历操作
Feb 27 jQuery
在layui中对table中的数据进行判断(0、1)转换为提示信息的方法
Sep 28 Javascript
JS+CSS+HTML实现“代码雨”类似黑客帝国文字下落效果
Mar 17 Javascript
微信小程序学习总结(三)条件、模板、文件引用实例分析
Jun 04 Javascript
微信小程序实现通讯录列表展开收起
Nov 18 Javascript
JavaScript中document.activeELement焦点元素介绍
Nov 27 Javascript
vue-router 手势滑动触发返回功能
Sep 30 #Javascript
Vue CLI3 开启gzip压缩文件的方式
Sep 30 #Javascript
JS数组实现分类统计实例代码
Sep 30 #Javascript
浅谈微信页面入口文件被缓存解决方案
Sep 29 #Javascript
vue实现弹框遮罩点击其他区域弹框关闭及v-if与v-show的区别介绍
Sep 29 #Javascript
vue使用v-for实现hover点击效果
Sep 29 #Javascript
vue 利用路由守卫判断是否登录的方法
Sep 29 #Javascript
You might like
PHP使用gmdate实现将一个UNIX 时间格式化成GMT文本的方法
2015/03/19 PHP
php文件下载处理方法分析
2015/04/22 PHP
jQuery AJAX 调用WebService实现代码
2010/03/24 Javascript
javascript 基础篇1 什么是js 建立第一个js程序
2012/03/14 Javascript
javascript+xml实现简单图片轮换(只支持IE)
2012/12/23 Javascript
js数组的操作详解
2013/03/27 Javascript
js中继承的几种用法总结(apply,call,prototype)
2013/12/26 Javascript
两种不同的方法实现js对checkbox进行全选和反选
2014/05/13 Javascript
详解JavaScript编程中的数组结构
2015/10/24 Javascript
第一篇初识bootstrap
2016/06/21 Javascript
JavaScript数据存储 Cookie篇
2016/07/02 Javascript
javascript history对象详解
2017/02/09 Javascript
jQuery UI Grid 模态框中的表格实例代码
2017/04/01 jQuery
Vue.js 2.5新特性介绍(推荐)
2017/10/24 Javascript
浅谈React Native Flexbox布局(小结)
2018/01/08 Javascript
JavaScript实现简单动态进度条效果
2018/04/06 Javascript
使用Vue的slot插槽分发父组件内容实现高度复用、更加灵活的组件(推荐)
2018/05/01 Javascript
jQuery点击页面其他部分隐藏下拉菜单功能
2018/11/27 jQuery
详解element-ui中form验证杂记
2019/03/04 Javascript
webpack4之如何编写loader的方法步骤
2019/06/06 Javascript
vscode 调试 node.js的方法步骤
2020/09/15 Javascript
[44:33]EG vs Liquid 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
python使用pyhook监控键盘并实现切换歌曲的功能
2014/07/18 Python
Python数据分析之如何利用pandas查询数据示例代码
2017/09/01 Python
Python实现将一个正整数分解质因数的方法分析
2017/12/14 Python
python类中super() 的使用解析
2019/12/19 Python
浅谈Python爬虫原理与数据抓取
2020/07/21 Python
使用scrapy ImagesPipeline爬取图片资源的示例代码
2020/09/28 Python
selenium如何定位span元素的实现
2021/01/13 Python
利用CSS3的transform做的动态时钟效果
2011/09/21 HTML / CSS
草莓巧克力:Shari’s Berries
2017/02/07 全球购物
2015年度党员自我评价范文
2015/03/03 职场文书
2015年试用期自我评价范文
2015/03/10 职场文书
2016年村党支部公开承诺书
2016/03/24 职场文书
使用Python获取字典键对应值的方法
2022/04/26 Python
项目中Nginx多级代理是如何获取客户端的真实IP地址
2022/05/30 Servers