时间:2021-05-18
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子组件的事件传递(任意组件事件传递)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在Vue中,父子组件的关系可以总结为props向下传递,事件向上传递。父组件通过props给子组件下发数据,子组件通过事件给父组件发送消息。看看它们是怎么工作的
前言之前在《Angular2父子组件数据传递之局部变量获取子组件其他成员》讲到过(如果有不懂的,可以先去看看),通过在子组件模版上设置局部变量的方式获取子组件的
使用v-on绑定自定义事件可以让子组件向父组件传递数据,用到了this.$emit(‘自定义的事件名称',传递给父组件的数据)Title总数是{{total}}
一、子组件向父组件传递一个值子组件:this.$emit('change',this.value);父组件://事件处理函数asynccostPlannedAm
在angular6.0使用教程:angular主从组件章节我们介绍了父组件向子组件传递数据,当时是在同一个页面传递数据的。而本章的angular数据传递将是在不