Angular2入門-數據綁定

▓▓▓▓▓▓ 大體介紹

  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的值,是組件類 -> 模板

相關文章
相關標籤/搜索