Angular自定义指令示例

1、涉及装饰器

下面例子中主要用到了@HostBinding()和@HostListener()两个装饰器,具体作用通过运行下面例子就可以明白。

2、创建指令

// 以下命令会创建TestDirective指令并自动添加到AppModule
ng g directive directive/test

3、TestDirective代码

import { Directive, HostBinding, HostListener, Renderer2, ElementRef } from '@angular/core';

@Directive({
  selector: '[appTest]'
})

export class TestDirective {

  @HostBinding('title')
  public title = 'This is a test title!';
    
  @HostBinding('id')
  public testId = '';

  constructor(
    private r2: Renderer2,
    private ef: ElementRef
  ) { }

  @HostListener('click')
  public clickTest() {
    this.testId = 'test-id';
    this.r2.setAttribute(this.ef.nativeElement, 'id', this.testId);
  }

  // test为class选择器名称, .test {font-size: 30px;color #f00;}
  &
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值