javascript – 用于修改点击处理的Angular2指令

我正在尝试编写一个Angular2属性指令来修改某些元素的行为.更具体地说,我想将属性应用于具有单击处理程序的某些元素,并防止在特定条件下执行绑定函数.

所以现在我有一个元素,例如:

<button (click)="onClick(param1,param2)"></button>

onClick是在承载按钮元素的组件上声明的函数.

我想做的是写一些类似的东西:

<button (click)="onClick(param1,param2)" online-only></button>

并有一个指令,如:

@Directive({
  selector: '[online-only]',})
export class OnlineOnlyDirective {
  @HostListener('click',['$event']) 
  onClick(e) {
    if(someCondition){
      e.preventDefault();
      e.stopPropagation();
    }
  }
}

但是首先执行click handler,因此不会给我的指令停止执行.

我想到的第二种方法是用我自己的处理程序替换(单击)例如([onlineClick] =“onClick”)并在指令认为合适时执行传递的函数,但这样我就不能将params传递给onClick函数而且有点我们要看看.

做这样的事情你有什么想法吗?

解决方法

我不知道强制Angular首先执行某个事件处理程序的方法.解决方法可能是使用自定义事件,例如:
<button (myClick)="onClick(param1,param2)" online-only></button>
@Directive({
  selector: '[myClick]',})
export class OnlineOnlyDirective {
  @Output() myClick: EventEmitter = new EventEmitter();
  @HostListener('click',['$event']) 
  onClick(e) {
    if(someCondition){
      e.preventDefault();
      e.stopPropagation();
    } else {
      this.myClick.next(e);
    }
  }
}

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...