1、场景
编写一个组件,有一个click事件,需要对外发送消息,但是有一些模块不需要点击事件,此时需要根据这俩种场景定义不同的样式。重新定义一个@Input()太过繁琐,此时通过对@Output()这个属性对象里面的一些属性来判断。
2、实现
EventEmitter类继承的Subject里面有个observers属性,该属性是个数组,里面是订阅者对象Subscriber,可以通过数组的长度来判断父组件是否订阅
@Output('onChartClick') onChartClick: EventEmitter<number> = new EventEmitter<number>(); /** * 获取是否有ChartClick的订阅者 * @returns {boolean} */ getChartClickSubscriber() { return !!this.onChartClick.observers.length; }
angualr判断父组件是否定义方法接收子组件Output发送的消息
最新推荐文章于 2022-09-21 10:43:47 发布