Angular2入門-數據綁定


▓▓▓▓▓▓ 大致介紹

  Angular2中數據綁定的方式默認是以單向方式,數據綁定的方式可以分為:

    1、屬性綁定和插值表達式 組件類-> 模板

    2、事件綁定:模板 -> 組件類

    3、雙向綁定: 模板 <-> 組件類

 

▓▓▓▓▓▓ 事件綁定

  事件綁定是把模板中的事件綁定到組件類中的方法上,例如在一個組件中的HTML代碼是:

<p>
    <a (click)="doClick($event)">點我</a>
</p>

 

  (click)表示要進行的操作,當用戶點擊時就會執行組件類中的doClick方法

export class BindComponent implements OnInit {

  constructor() { }

  ngOnInit() {
  }

  doClick(event: any){
      console.log(event.target.innertext);
  }

}

 

▓▓▓▓▓▓ 屬性綁定和插值表達式

  其實 屬性綁定和插值表達式是同一個東西,因為在解析代碼時,插值表達式會轉換為屬性綁定,所以你想用哪個就用哪個

  下面的代碼作用都是一樣的

<!-- 插值表達式 -->
<img src="{{imgUrl}}"  />

<!-- 屬性綁定 -->
<img [src]="imgUrl" />

 

  屬性綁定又分為HTML屬性綁定和DOM屬性綁定,他們之間的區別是什么?先來看一個例子

<input type="text" value="hello" (input)="doInput($event)" />
  doInput(event: any){
      console.log(event.target.value);
      console.log(event.target.getAttribute('value'));
  }

  

  瀏覽器的顯示:

 

  可以看到event.target.value是獲取的DOM屬性,是可變的。表示當前元素的狀態

  而event.target.getAttribute("value")獲取的是HTML屬性,是不可變的。只負責初始化HTML元素,不可改變

  注意:

    1、有些DOM屬性沒有映射的HTML屬性,同樣有些HTML屬性也沒有映射的DOM屬性

    2、模板綁定的是DOM屬性

 

 

  HTML屬性綁定
    1、基本HTML屬性綁定

      <td [attr.colspan]="表達式"></td>


    2、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


    3、樣式綁定

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

 

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM