@HostBinding()和@HostListener()在自定義指令時很是有用。@HostBinding()能夠爲指令的宿主元素添加類、樣式、屬性等,而@HostListener()能夠監聽宿主元素上的事件。spring
@HostBinding()和@HostListener()不單單用在自定義指令,只是在自定義指令中用的較多app
本文基於Angular2+dom
下面咱們經過實現一個在輸入時實時改變字體和邊框顏色的指令,學習@HostBinding()和@HostListener()的用法。學習
import { Directive, HostBinding, HostListener } from '@angular/core'; @Directive({ selector: '[appRainbow]'① }) export class RainbowDirective{ possibleColors = [ 'darksalmon', 'hotpink', 'lightskyblue', 'goldenrod', 'peachpuff', 'mediumspringgreen', 'cornflowerblue', 'blanchedalmond', 'lightslategrey' ];② @HostBinding('style.color') color: string; @HostBinding('style.borderColor') borderColor: string;③ @HostListener('keydown') onKeydown(){④ const colorPick = Math.floor(Math.random() * this.possibleColors.length); this.color = this.borderColor = this.possibleColors[colorPick]; } }
說一下上面代碼的主要部分:
①:爲咱們的指令取名爲appRainbow
②:定義咱們須要展現的全部可能的顏色
③:定義並用@HostBinding()裝飾color和borderColor,用於設置樣式
④:用@HostListener()監聽宿主元素的keydown事件,爲color和borderColor隨機分配顏色字體
OK,如今就來使用咱們的指令:this
<input appRainbow>
效果就像這樣:
code
NOTE:別忘了把指令引入你的模塊blog
以上!事件