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的值,是组件类 -> 模板