指令 - 创建属性指令

优质
小牛编辑
136浏览
2023-12-01

View Example

我们有礼貌,所以不是仅仅将用户发送到新页面,而是通过创建属性指令并将其附加到按钮,来询问他们是否确定跳转。

  1. selector: `[appConfirm]`
  2. })
  3. export class ConfirmDirective {
  4. @HostListener('click', ['$event'])
  5. confirmFirst(event: Event) {
  6. return window.confirm('Are you sure you want to do this?');
  7. }
  8. }

通过在类上使用@Directive装饰器并指定选择器来创建指令。对于指令,选择器名称必须为camelCase,并用方括号括起来,以指定它是属性绑定。我们使用@HostListener装饰器来监听它所附加的组件或元素上的事件。 在这种情况下,我们正在观察点击事件并传递$event关键字给出的事件详细信息。 接下来,我们要将此指令附加到我们之前创建的按钮。

然而,请注意,该按钮不能按预期工作。这是因为当我们监听点击事件并显示确认对话框时,组件的点击处理程序在指令的点击处理程序之前运行,两者之间没有通信。为此,我们需要重写我们的指令以使用组件的点击处理程序。

  1. @Directive({
  2. selector: `[appConfirm]`
  3. @Input() appConfirm = () => {};
  4. @HostListener('click', ['$event'])
  5. confirmFirst() {
  6. const confirmed = window.confirm('Are you sure you want to do this?');
  7. if(confirmed) {
  8. this.appConfirm();
  9. }
  10. }
  11. }

在这里,我们想要指定在发送确认对话框后需要执行什么操作,为此,我们创建一个类似于组件上的输入绑定。 我们将使用我们的指令名称来进行这个绑定,我们的组件代码的变化如下:

View Example

  1. @Directive({
  2. selector: `[appConfirm]`
  3. export class ConfirmDirective {
  4. @Input() appConfirm = () => {};
  5. @Input() confirmMessage = 'Are you sure you want to do this?';
  6. @HostListener('click', ['$event'])
  7. confirmFirst() {
  8. const confirmed = window.confirm(this.confirmMessage);
  9. if(confirmed) {
  10. this.appConfirm();
  11. }
  12. }
  13. }

View Example

我们的指令获得一个新的输入属性,它表示确认对话框消息,我们传递给window.confirm调用。要利用这个新的输入属性,我们添加另一个绑定到我们的按钮。

现在我们有一个可以在跳转到一个新页面之前自定义确认消息的按钮。