Angular 2.0+ 的数据绑定的实现示例


Posted in Javascript onAugust 09, 2017

这两天学习了Angular感觉 数据绑定这个地方知识点挺多的,而且很重要,所以,今天添加一点小笔记。

前言

我们使用如下的组件代码进行本文的所有演示

export class AppComponent {
 angularLogo = 'https://angular.io/assets/images/logos/angular/angular.svg';
 userName="David";
 newItem() {
  console.log("Hello world!");
 }
}

组件到DOM - Component to DOM

属性绑定,单向数据绑定。可以有下面三种不同的书写方式。

![]({{ angularLogo }})
 <img [src]="angularLogo">
 ![](angularLogo)
  1. 使用字符串插值方式。 {{ 变量名 }}
  2. 使用方挎号 [] ,方挎号内包含属性名。
  3. 在属性名前添加bind- 也可以达到同样的效果。

DOM到组件 - DOM to Component

事件绑定,当发生特定的DOM事件(例如:click,change,keyup)时,调用组件中指定方法。在下面的示例中,单击按钮时调用该组件的newItem()方法:

<button (click)="newItem()"></button>

双向数据绑定

使用[(ngModel)]="变量名"方式,可以实现双向数据绑定。

<input type="text" [(ngModel)]="userName">
<h1>Hello {{userName}}!</h1>

从Angular 2.x版开始,Angular中的数据绑定真的只是归结为属性绑定和事件绑定。 双向数据绑定是不存在的东西。 如果没有ngModel指令,我们如何实现双向数据绑定?如下所示:

<input [value]="username" (input)="username = $event.target.value">
<p>Hello {{username}}!</p>

我们来看看这里面发生了什么?

  1. [value]=”username” - 绑定变量username input元素的value属性。
  2. (input)=”username = $event.target.value” - 绑定input元素的input事件到js代码username = $event.target.value
  3. $event - 在Angular的事件绑定中暴露的表达式,它的值为事件的载体。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery表格内容筛选实现思路及代码
Apr 16 Javascript
JavaScript通过字符串调用函数的实现方法
Mar 18 Javascript
javascript自定义事件功能与用法实例分析
Nov 08 Javascript
Vue代码分割懒加载的实现方法
Nov 23 Javascript
详解Nuxt.js Vue服务端渲染摸索
Feb 08 Javascript
微信小程序实现人脸识别
May 25 Javascript
js+canvas实现验证码功能
Sep 21 Javascript
vue基础之data存储数据及v-for循环用法示例
Mar 08 Javascript
Vue中Table组件Select的勾选和取消勾选事件详解
Mar 19 Javascript
vue读取本地的excel文件并显示在网页上方法示例
May 29 Javascript
jQuery擦除插件eraser使用方法详解
Jan 11 jQuery
微信小程序实现列表滚动头部吸顶的示例代码
Jul 12 Javascript
Ionic3实现图片瀑布流布局
Aug 09 #Javascript
JavaScript闭包和回调详解
Aug 09 #Javascript
ionic 3.0+ 项目搭建运行环境的教程
Aug 09 #Javascript
JavaScript实现的浏览器下载文件的方法
Aug 09 #Javascript
Node.js五大应用性能技巧小结(必须收藏)
Aug 09 #Javascript
详解用node搭建简单的静态资源管理器
Aug 09 #Javascript
vue页面使用阿里oss上传功能的实例(二)
Aug 09 #Javascript
You might like
php 什么是PEAR?
2009/03/19 PHP
php使用codebase生成随机数
2014/03/25 PHP
PHP安全的URL字符串base64编码和解码
2014/06/19 PHP
php源码分析之DZX1.5字符串截断函数cutstr用法
2015/06/17 PHP
yii2.0整合阿里云oss删除单个文件的方法
2017/09/19 PHP
ThinkPHP框架实现的邮箱激活功能示例
2018/06/15 PHP
showModalDialog 和 showModelessDialog
2007/01/22 Javascript
javaScript 关闭浏览器 (不弹出提示框)
2010/01/31 Javascript
JS Excel读取和写入操作(模板操作)实现代码
2010/04/11 Javascript
jquery下为Event handler传递动态参数的代码
2011/01/06 Javascript
从零开始学习jQuery (三) 管理jQuery包装集
2011/02/23 Javascript
JS的document.all函数使用示例
2013/12/30 Javascript
禁止拷贝网页内容的js代码
2014/01/22 Javascript
javascript中slice(),splice(),split(),substring(),substr()使用方法
2015/03/13 Javascript
JQuery点击行tr实现checkBox选中的简单实例
2016/05/26 Javascript
jquery使用on绑定a标签无效 只能用live解决
2016/06/02 Javascript
js Canvas实现圆形时钟教程
2016/09/19 Javascript
JS中的数组转变成JSON格式字符串的方法
2017/05/09 Javascript
iscroll.js滚动加载实例详解
2017/07/18 Javascript
JavaScript设计模式之构造函数模式实例教程
2018/07/02 Javascript
Element InfiniteScroll无限滚动的具体使用方法
2020/07/27 Javascript
[56:58]VP vs Optic 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
Python及PyCharm下载与安装教程
2017/11/18 Python
Python内建模块struct实例详解
2018/02/02 Python
Python 通过调用接口获取公交信息的实例
2018/12/17 Python
Python判断对象是否相等及eq函数的讲解
2019/02/25 Python
Python multiprocessing多进程原理与应用示例
2019/02/28 Python
python GUI库图形界面开发之PyQt5布局控件QHBoxLayout详细使用方法与实例
2020/03/06 Python
python中not、and和or的优先级与详细用法介绍
2020/11/03 Python
夏威夷灵感服装及配饰:Reyn Spooner
2018/09/18 全球购物
澳大利亚在线批发商:Simply Wholesale
2021/02/24 全球购物
中等生评语大全
2014/05/04 职场文书
2014年征兵标语
2014/06/20 职场文书
党的群众路线对照检查材料
2014/09/22 职场文书
2016七一建党节慰问信
2015/11/30 职场文书
Python机器学习之PCA降维算法详解
2021/05/19 Python