Angular2中數據綁定的方式默認是以單向方式,數據綁定的方式能夠分爲:css
一、屬性綁定和插值表達式 組件類-> 模板瀏覽器
二、事件綁定:模板 -> 組件類this
三、雙向綁定: 模板 <-> 組件類spa
事件綁定是把模板中的事件綁定到組件類中的方法上,例如在一個組件中的HTML代碼是:雙向綁定
<p> <a (click)="doClick($event)">點我</a> </p>
(click)表示要進行的操做,當用戶點擊時就會執行組件類中的doClick方法code
export class BindComponent implements OnInit {
constructor() { }
ngOnInit() {
}
doClick(event: any){
console.log(event.target.innertext);
}
}
其實 屬性綁定和插值表達式是同一個東西,由於在解析代碼時,插值表達式會轉換爲屬性綁定,因此你想用哪一個就用哪一個blog
下面的代碼做用都是同樣的事件
<!-- 插值表達式 --> <img src="{{imgUrl}}" /> <!-- 屬性綁定 --> <img [src]="imgUrl" />
屬性綁定又分爲HTML屬性綁定和DOM屬性綁定,他們之間的區別是什麼?先來看一個例子get
<input type="text" value="hello" (input)="doInput($event)" />
doInput(event: any){ console.log(event.target.value); console.log(event.target.getAttribute('value')); }
瀏覽器的顯示:input
能夠看到event.target.value是獲取的DOM屬性,是可變的。表示當前元素的狀態
而event.target.getAttribute("value")獲取的是HTML屬性,是不可變的。只負責初始化HTML元素,不可改變
注意:
一、有些DOM屬性沒有映射的HTML屬性,一樣有些HTML屬性也沒有映射的DOM屬性
二、模板綁定的是DOM屬性
HTML屬性綁定
一、基本HTML屬性綁定
<td [attr.colspan]="表達式"></td>
二、css綁定
<div class="a" [class]="b"></div> //b會徹底替代a <div [class.a]="fn()"></div> //fn()返回true,false,若是true添加.a <div [ngClass]="{a:isA,b:isB}"></div> //b會徹底替代a
三、樣式綁定
<button [style.color]="a?red:green">button</button> <button [ngStyle]="{'font-style':a?'red':'green'}">button</button>
雙向綁定能夠從組件類 -> 模板,也能夠從模板 -> 組件類
例子:
<input type="text" [(ngModel)]="name" (input)="doInput()" />
private name: string = 'asdf'; doInput(){ setInterval(() => { this.name = 'sdf'; },3000); }
利用[(ngModel)]能夠實現雙向數據綁定,首先在輸入框中修改name,從而改變組件類中name的值,是模板組 -> 件類,修改值以後三秒,又從新設置name的值,是組件類 -> 模板