Angular4学习笔记之DOM属性绑定

发布时间:2019-06-04 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了Angular4学习笔记之DOM属性绑定脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

简介

使用插值表达式将一个表达式的值显示在模版上

<img src="{{imgUrl}}" alt="">
<h1>{{productTitle}}</h1>

使用方括号将HTML标签的一个属性值绑定到一个表达式上

<img [src]="imgUrl" alt="">

使用小括号将组件控制器的一个方法绑定到模版上面的一个事件的处理器

<button (click)="onClickButton($event)">按钮绑定事件</button>

注意

开始下面的例子之前,请先确认已经新建了一个工程。如果没有,请查看:Angular2学习笔记之Angular CLI 安装和使用教程

事件绑定

clipboard.png

准备工作

了解目的:在模版的界面上面增加一个按钮,然后通过小括号绑定一个事件。
新建一个 bind 组件,使用命令:  ng g c bind

修改 bind.component.htML

<!-- 界面增加代码 -->
<button (click)="onClickButton($event)">按钮绑定事件</button>

修改 bind.COMponent.ts

@H_304_161@//在 BindComponent 类方法中增加方法体 onClickButton(event: any){ console.LOG(event); }

修改 app.component.html

<!-- 增加 app-bind 组件 -->
<app-bind></app-bind>

图示:

Angular4学习笔记之DOM属性绑定

Dom属性绑定

例子一

插值表达式 与 属性绑定 之间的关系

两种方式都可以实现,Angular 在实现的逻辑上面是: 在程序加载组件的时候,会先将 "插值表达式" 翻译"属性绑定"

修改 bind.component.html

<!-- 界面增加代码 -->

<!-- 属性绑定 -->
<img [src]="imgUrl" alt="">

<!-- 插值表达式绑定 -->
<img src="{{imgUrl}}" alt="">

修改 bind.component.ts

//增加变量
imgUrl: string = "http://placehold.it/320x280";

图示:

clipboard.png

例子二

dom 属性 与 html 属性的区别

HTML元素的 DOM属性和 HTML 属性是有部分区别的,这点需要明确差异。

修改 bind.component.html

<!-- 增加代码 -->
<div>
  <input type="text" value="Tom" (input)="onInputEvent($event)">
</div>

修改 bind.component.ts

//增加 event事件
onInputEvent(event: any){
  //获取的是 dom 属性,即输入属性
  console.log(event.target.value);

  //获取的是 html 属性,也就是初始化的属性
  console.log(event.target.getAttribute("value"));

}

图示:

Angular4学习笔记之DOM属性绑定

总结:

1.少量的 HTML属性和 DOM属性之间有这 1 :1 的映射关系,如 :id
2.有些有 HTML属性,没有DOM 属性, 如:colspan
3.有些有 DOM属性,没有HTML 属性,如:textContent
4.就算名字一样,DOM属性和HTML属性获取的内容可能不一样
5.模版绑定是通过DOM属性绑定的,而不是通过HTML属性
6.HTML属性指定了初始值,DOM属性表示当前值;DOM属性的值可以改变HTML的值不能改变
@H_406_449@例子部分完整代码

bind.component.html

<p>
  bind works!
</p>

<button (click)="onClickButton($event)">按钮绑定事件</button>

<div>
  <!-- 属性绑定 -->
  <img [src]="imgUrl" alt="">

  <!-- 插值表达式绑定 -->
  <img src="{{imgUrl}}" alt="">
</div>

<div>
  <input type="text" value="Tom" (input)="onInputEvent($event)">
</div>

bind.component.ts

import { Component, OnInit } From '@angular/core';

@Component({
  selector: 'app-bind',
  templateUrl: './bind.component.html',
  styleUrls: ['./bind.component.css']
})
export class BindComponent implements OnInit {

  imgUrl: string = "http://placehold.it/320x280";

  constructor() { }

  ngOnInit() {
  }

  onClickButton(event: any){
    console.log(event);
  }

  onInputEvent(event: any){
    //获取的是 dom 属性,即输入属性
    console.log(event.target.value);

    //获取的是 html 属性,也就是初始化的属性
    console.log(event.target.getAttribute("value"));
  }
}

脚本宝典总结

以上是脚本宝典为你收集整理的Angular4学习笔记之DOM属性绑定全部内容,希望文章能够帮你解决Angular4学习笔记之DOM属性绑定所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。