Angular2指令修改点击处理

Angular2 Directive to modify click handling(Angular2指令修改点击处理)
本文介绍了Angular2指令修改点击处理的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

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

I am trying to write a Angular2 attribute directive to modify the behaviour of certain elements. More specifically I want to apply an attribute to certain elements that have click handlers and prevent the bound function to be executed under certain conditions.

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

So now I have an element e.g.:

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

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

onClick is a function declared on the component that hosts the button element doing some work.

我想做的是这样写:

<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();
    }
  }
}

但是单击处理程序首先执行,因此我的指令没有机会停止执行.

But click handler is executed first, thus not giving my directive the opportunity to stop its execution.

我想到的第二种方法是用我自己的处理程序替换(单击),例如([onlineClick]="onClick")并在指令认为合适时执行传递的函数,但是这样我不能将参数传递给 onClick 函数和看起来有点奇怪.

A second approach I thought about was replacing (click) with my own handler e.g.( [onlineClick]="onClick" ) and execute the passed function when the directive thinks fit, but this way I cannot pass params to onClick function and is a bit weirder to look at.

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

Do you have any thoughts on doing something like that?

推荐答案

我不知道有什么方法可以强制 Angular 先执行某个事件处理程序.一种解决方法可能是使用自定义事件,例如:

I don't know of a way to force Angular to execute a certain event handler first. A workaround might be to use a custom event like:

<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);
    }
  }
}

这篇关于Angular2指令修改点击处理的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

在开发JS过程中,会经常遇到两个小数相运算的情况,但是运算结果却与预期不同,调试一下发现计算结果竟然有那么长一串尾巴。如下图所示: 产生原因: JavaScript对小数运算会先转成二进制,运算完毕再转回十进制,过程中会有丢失,不过不是所有的小数间运算会
问题描述: 在javascript中引用js代码,然后导致反斜杠丢失,发现字符串中的所有\信息丢失。比如在js中引用input type=text onkeyup=value=value.replace(/[^\d]/g,) ,结果导致正则表达式中的\丢失。 问题原因: 该字符串含有\,javascript对字符串进行了转
Rails/Javascript: How to inject rails variables into (very) simple javascript(Rails/Javascript:如何将 rails 变量注入(非常)简单的 javascript)
CoffeeScript always returns in anonymous function(CoffeeScript 总是以匿名函数返回)
Ordinals in words javascript(javascript中的序数)
getFullYear returns year before on first day of year(getFullYear 在一年的第一天返回前一年)