Angular4学习教程之DOM属性绑定详解


Posted in Javascript onJanuary 04, 2018

前言

DOM 元素触发的一些事件通过 DOM 层级结构传播,事件首先由最内层的元素开始,然后传播到外部元素,直到它们到根元素,这种传播过程称为事件冒泡。本文主要介绍了关于Angular4 DOM属性绑定的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

简介

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

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

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

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

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

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

注意

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

事件绑定

Angular4学习教程之DOM属性绑定详解

准备工作

了解目的:在模版的界面上面增加一个按钮,然后通过小括号绑定一个事件。

新建一个 bind 组件,使用命令:  ng g c bind

修改 bind.component.html

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

修改 bind.component.ts

//在 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;

图示:

Angular4学习教程之DOM属性绑定详解

例子二

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的值不能改变

例子部分完整代码

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"));
 }
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
学习JavaScript的最佳方法分享
Oct 21 Javascript
利用javascript解决图片缩放及其优化的代码
May 23 Javascript
用js的for循环获取radio选中的值
Oct 21 Javascript
初识SmartJS - AOP三剑客
Jun 08 Javascript
js实现内容显示并使用json传输数据
Mar 16 Javascript
AngularJS动态加载模块和依赖的方法分析
Nov 08 Javascript
laravel5.3 vue 实现收藏夹功能实例详解
Jan 21 Javascript
三分钟学会用ES7中的Async/Await进行异步编程
Jun 14 Javascript
jquery获取select选中值的文本,并赋值给另一个输入框的方法
Aug 21 jQuery
vscode vue 文件模板的配置方法
Jul 23 Javascript
介绍一下28个JS常用数组方法
May 06 Javascript
JS实现简易换图时钟功能分析
Jan 04 #Javascript
Angular4学习之Angular CLI的安装与使用教程
Jan 04 #Javascript
利用Vue2.x开发实现JSON树的方法
Jan 04 #Javascript
vue-cli配置文件——config篇
Jan 04 #Javascript
jQuery封装animate.css的实例
Jan 04 #jQuery
js 公式编辑器 - 自定义匹配规则 - 带提示下拉框 - 动态获取光标像素坐标
Jan 04 #Javascript
浅谈vuex 闲置状态重置方案
Jan 04 #Javascript
You might like
使用ThinkPHP自带的Http类下载远程图片到本地的实现代码
2011/08/02 PHP
关于zend studio 出现乱码问题的总结
2013/06/23 PHP
php将日期格式转换成xx天前的格式
2015/04/16 PHP
在IIS下安装PHP扩展的方法(超简单)
2017/04/10 PHP
php workerman定时任务的实现代码
2018/12/23 PHP
javascript 词法作用域和闭包分析说明
2010/08/12 Javascript
jquery索引在使用中的一些困惑
2013/10/24 Javascript
快速解决jQuery与其他库冲突的方法介绍
2014/01/02 Javascript
angularjs指令中的compile与link函数详解
2014/12/06 Javascript
js获取域名的方法
2015/01/27 Javascript
修复jQuery tablesorter无法正确排序的bug(加千分位数字后)
2016/03/30 Javascript
基于Bootstrap和jQuery构建前端分页工具实例代码
2016/11/23 Javascript
ReactJs快速入门教程(精华版)
2016/11/28 Javascript
knockoutjs模板实现树形结构列表
2017/07/31 Javascript
cnpm加速Angular项目创建的方法
2018/09/07 Javascript
layer 关闭指定弹出层的例子
2019/09/25 Javascript
JavaScript运行机制实例分析
2020/04/11 Javascript
解决Echarts 显示隐藏后宽度高度变小的问题
2020/07/19 Javascript
antd中table展开行默认展示,且不需要前边的加号操作
2020/11/02 Javascript
python使用xauth方式登录饭否网然后发消息
2014/04/11 Python
TensorFlow 模型载入方法汇总(小结)
2018/06/19 Python
对python 中class与变量的使用方法详解
2019/06/26 Python
python集合删除多种方法详解
2020/02/10 Python
40行Python代码实现天气预报和每日鸡汤推送功能
2020/02/27 Python
使用jupyter notebook将文件保存为Markdown,HTML等文件格式
2020/04/14 Python
Opencv常见图像格式Data Type及代码实例
2020/11/02 Python
python中HTMLParser模块知识点总结
2021/01/25 Python
vivo智能手机官方商城:vivo
2016/09/22 全球购物
保密协议书范本
2014/04/22 职场文书
法制宣传日活动总结
2014/04/29 职场文书
经典团队口号大全
2014/06/21 职场文书
2014年药店工作总结
2014/11/20 职场文书
房屋租房协议书范本
2014/12/04 职场文书
初中毕业生自我评价
2015/03/02 职场文书
2015年社区综治工作总结
2015/04/21 职场文书
python中subplot大小的设置步骤
2021/06/28 Python