首頁 >web前端 >js教程 >AngularJS中@HostBinding()和@HostListener()的使用區別

AngularJS中@HostBinding()和@HostListener()的使用區別

php中世界最好的语言
php中世界最好的语言原創
2018-04-12 11:42:001651瀏覽

這次帶給大家AngularJS中@HostBinding()和@HostListener()的使用區別,使用AngularJS中@HostBinding()和@HostListener()的注意事項有哪些,以下就是實戰案例,一起來看一下。

@HostBinding()和@HostListener()在自訂指令時非常有用。 @HostBinding()可以為指令的宿主元素添加類別、樣式、屬性等,而@HostListener()可以監聽宿主元素上的事件

@HostBinding()和@HostListener()不只用在自訂指令,只是在自訂指令中用的較多

# 本文基於Angular2+

下面我們透過實作一個在輸入時即時改變字體和邊框顏色的指令,學習@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隨機分配顏色

#相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

axios發送請求時springmvc無法接受參數

怎麼透過axios實現網路請求功能

以上是AngularJS中@HostBinding()和@HostListener()的使用區別的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn