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 相关文章推荐
js用图作提交按钮或超连接
Mar 26 Javascript
javascript 选择文件夹对话框(web)
Jul 07 Javascript
JavaScript 判断浏览器是否支持SVG的代码
Mar 21 Javascript
浅析LigerUi开发中谨慎载入common.css文件
Jul 09 Javascript
Javascript学习笔记之相等符号与严格相等符号
Nov 23 Javascript
jquery判断当前浏览器的实现代码
Nov 07 Javascript
jQuery的三种bind/One/Live/On事件绑定使用方法
Feb 23 Javascript
简单实现js上传文件功能
Aug 21 Javascript
vue2.0页面前进刷新回退不刷新的实现方法
Jul 31 Javascript
JavaScript实现构造json数组的方法分析
Aug 17 Javascript
JavaScript中十种一步拷贝数组的方法实例详解
Apr 22 Javascript
js实现贪吃蛇游戏 canvas绘制地图
Sep 09 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
PHP反射使用实例和PHP反射API的中文说明
2014/07/02 PHP
js中cookie的使用详细分析
2008/05/28 Javascript
Jquery多选下拉列表插件jquery multiselect功能介绍及使用
2013/05/24 Javascript
addEventListener()第三个参数useCapture (Boolean)详细解析
2013/11/07 Javascript
一个JavaScript防止表单重复提交的实例
2014/10/21 Javascript
让JavaScript中setTimeout支持链式操作的方法
2015/06/19 Javascript
Jquery幻灯片特效代码分享--打开页面随机选择切换方式(3)
2015/08/15 Javascript
基于jquery实现页面滚动到底自动加载数据的功能
2015/12/19 Javascript
jQuery Mobile弹出窗、弹出层知识汇总
2016/01/05 Javascript
JavaScript实现一个空中避难的小游戏
2017/06/06 Javascript
JavaScript实现简单评论功能
2017/08/17 Javascript
Javascript中prototype与__proto__的关系详解
2018/03/11 Javascript
详解webpack-dev-server使用方法
2018/09/14 Javascript
4个顶级开源JavaScript图表库
2018/09/29 Javascript
原生js实现贪食蛇小游戏的思路详解
2019/11/26 Javascript
ES6 Generator基本使用方法示例
2020/06/06 Javascript
详解JavaScript数据类型和判断方法
2020/09/04 Javascript
[55:04]海涛DOTA2死魂复燃6.82版本介绍
2014/09/28 DOTA
Python CSV模块使用实例
2015/04/09 Python
Python3安装Scrapy的方法步骤
2017/11/23 Python
JavaScript中的模拟事件和自定义事件实例分析
2018/07/27 Python
python字符串循环左移
2019/03/08 Python
python使用Plotly绘图工具绘制水平条形图
2020/03/25 Python
Python之NumPy(axis=0 与axis=1)区分详解
2019/05/27 Python
numpy.meshgrid()理解(小结)
2019/08/01 Python
Python使用import导入本地脚本及导入模块的技巧总结
2019/08/07 Python
Win10 安装PyCharm2019.1.1(图文教程)
2019/09/29 Python
Python爬取腾讯视频评论的思路详解
2019/12/19 Python
中餐厅主管的职责范文
2014/02/04 职场文书
学习之星事迹材料
2014/05/17 职场文书
化妆品活动策划方案
2014/05/23 职场文书
爱耳日宣传活动总结
2014/07/05 职场文书
2014年生产管理工作总结
2014/12/23 职场文书
2016元旦主持人经典开场白台词
2015/12/03 职场文书
MySQL系列之十三 MySQL的复制
2021/07/02 MySQL
python的netCDF4批量处理NC格式文件的操作方法
2022/03/21 Python