繁体   English   中英

如何使用HostListener自定义元素? (角2)

[英]How to user HostListener for custom elements? ( angular 2)

我可以使用HostListener进行文档侦听:

@HostListener('document:click', ['$event'])
someAction(event) {
    console.log('done');
}

如何监听元素的click事件。 例如:

<span class="someClass"></span>

@HostListener('click', ['$event'])用于侦听主机元素本身上的事件。 没有其他可用的用例。

一个例外是全局事件,例如您与诸如window:document:body类的全局事件目标一起使用的事件。

聆听任意元素使用

<span class="someClass" (click)="someAction($event)"></span>

Gunter的答案是正确的,但是您可以使用HostListener来制定指令,以获得更全面的使用感(例如“收藏夹” /“喜欢”按钮)。

@Directive({
selector: '.favorite'
})
class FavoriteDirective(){
 @HostListener('click', ['$event.target']) onClick(_element) {
    ...
  }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM