浅谈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 相关文章推荐
使用prototype.js进行异步操作
Feb 07 Javascript
JS location几个方法小姐
Jul 09 Javascript
js实现的GridView即表头固定表体有滚动条且可滚动
Feb 19 Javascript
使用 js+正则表达式为关键词添加链接
Nov 11 Javascript
AngularJS实现表单手动验证和表单自动验证
Dec 09 Javascript
基于jQuery实现仿51job城市选择功能实例代码
Mar 02 Javascript
Sort()函数的多种用法
Mar 20 Javascript
Iscrool下拉刷新功能实现方法(推荐)
Jun 26 Javascript
jQuery Layer弹出层传值到父页面的实现代码
Aug 17 jQuery
微信小程序实现默认第一个选中变色效果
Jul 17 Javascript
vue路由--网站导航功能详解
Mar 29 Javascript
详解一个小实例理解js原型和继承
Apr 24 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生成随机密码
2015/10/30 PHP
Yii框架应用组件用法实例分析
2020/05/15 PHP
基于JavaScript 声明全局变量的三种方式详解
2013/05/07 Javascript
客户端js性能优化小技巧整理
2013/11/05 Javascript
js实现select组件的选择输入过滤代码
2014/10/14 Javascript
Js可拖拽放大的层拖动特效实现方法
2015/02/25 Javascript
iscroll碰到Select无法选择下拉刷新的解决办法
2016/05/21 Javascript
关于input全选反选恶心的异常情况
2016/07/24 Javascript
js判断出两个字符串最大子串的函数实现方法
2016/11/01 Javascript
JavaScript中数组Array.sort()排序方法详解
2017/03/01 Javascript
vue下拉菜单组件(含搜索)的实现代码
2018/11/25 Javascript
利用layer实现表单完美验证的方法
2019/09/26 Javascript
Node.js控制台彩色输出的方法与原理实例详解
2019/12/01 Javascript
tracking.js实现前端人脸识别功能
2020/04/16 Javascript
小程序实现图片移动缩放效果
2020/05/26 Javascript
python访问sqlserver示例
2014/02/10 Python
python 调用HBase的简单实例
2016/12/18 Python
sublime text 3配置使用python操作方法
2017/06/11 Python
Python3实战之爬虫抓取网易云音乐的热门评论
2017/10/09 Python
windows 下python+numpy安装实用教程
2017/12/23 Python
Python中数组,列表:冒号的灵活用法介绍(np数组,列表倒序)
2018/04/18 Python
python进行TCP端口扫描的实现
2018/12/21 Python
python爬取盘搜的有效链接实现代码
2019/07/20 Python
python文件绝对路径写法介绍(windows)
2019/12/25 Python
python统计函数库scipy.stats的用法解析
2020/02/25 Python
python怎么删除缓存文件
2020/07/19 Python
python实现发送QQ邮件(可加附件)
2020/12/23 Python
美国医生配方营养补充剂供应商:Healthy Directions
2019/07/10 全球购物
影视艺术学院毕业生自荐信
2013/11/13 职场文书
企业文化建设实施方案
2014/03/22 职场文书
搞笑爱情保证书
2014/04/29 职场文书
2014报到证办理个人委托书
2014/10/08 职场文书
教师党员学习群众路线心得体会
2014/11/04 职场文书
小学班主任自我评价
2015/03/11 职场文书
新娘婚礼答谢词
2015/09/29 职场文书
【HBU】数据库第四周 单表查询
2021/04/05 SQL Server