Angular自定义组件实现数据双向数据绑定的实例


Posted in Javascript onDecember 11, 2017

学过Angular的同学都知道,输入框通过[(ngModel)]实现双向数据绑定,那么自定义组件能不能实现双向数据绑定呢?答案是肯定的。

Angular中,我们常常需要通过方括号[]和圆括号()实现组件间的交互:

Angular自定义组件实现数据双向数据绑定的实例

那么在[]()的基础上,如何实现组件的双向数据绑定?

例子如下。

子组件:

<!--testDataBinding.component.html-->

<h1>childStatus: {{childStatus}}</h1>
//testDataBinding.component.ts

export class TestDataBindingComponent implements OnInit{
 @Input() childStatus;
 @Output() childStatusChange = new EventEmitter();
 ngOnInit(){
 setTimeout(()=>{
  this.childStatus = false;
  this.childStatusChange.emit(this.childStatus);
 },5000);
 }
}

注意这里的写法,这是关键所在,输出属性前半部分必须与输入属性相同,输入属性可以随意取名,输出属性需在输入属性基础上加上Change,比如你的输入属性是myData,那么输出属性就必须是myDataChange。

父组件:

<!--app.component.html-->

<test-binding [(childStatus)]="parentStatus"></test-binding>
<h1>parentStatus: {{parentStatus}}</h1>
//app.component.ts

import { Component,OnInit } from '@angular/core';
@Component({
 selector: 'my-app',
 templateUrl: './app.component.html',
 styleUrls: ['./app.component.css']
})
export class AppComponent implements OnInit{
 parentStatus: boolean = true;
 ngOnInit(){
 setTimeout(()=>{
  this.parentStatus = true;
 },10000);
 }
}

在父组件我们初始化parentStatustrue,并把它传到子组件TestDataBindingComponent

在子组件里,5秒后我们把childStatus设为false,看它能不能传到父组件。再过5秒,我们在父组件将parentStatus设为true,看它能不能传到子组件。

Angular自定义组件实现数据双向数据绑定的实例

事实证明,子组件值变化后,父组件的值也跟着变化;父组件值变化后子组件的值也跟着变了!

我们实现了双向绑定!

查看本文代码和效果,可点击这里

以上这篇Angular自定义组件实现数据双向数据绑定的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 判断指定字符串是否为有效数字
May 11 Javascript
jQuery实现仿百度帖吧头部固定导航效果
Aug 07 Javascript
javascript数组克隆简单实现方法
Dec 16 Javascript
jQuery+formdata实现上传进度特效遇到的问题
Feb 24 Javascript
JavaScript学习笔记之数组的增、删、改、查
Mar 23 Javascript
JavaScript实现替换字符串中最后一个字符的方法
Mar 07 Javascript
vue数字类型过滤器的示例代码
Sep 07 Javascript
ES6学习教程之模板字符串详解
Oct 09 Javascript
jQuery实现DIV响应鼠标滑过由下向上展开效果示例【测试可用】
Apr 26 jQuery
Node.js命令行/批处理中如何更改Linux用户密码浅析
Jul 22 Javascript
Vue动态修改网页标题的方法及遇到问题
Jun 09 Javascript
高效jQuery选择器的5个技巧实例分析
Nov 26 jQuery
node.js将MongoDB数据同步到MySQL的步骤
Dec 10 #Javascript
Node.js中sequelize时区的配置方法
Dec 10 #Javascript
node.js多个异步过程中判断执行是否完成的解决方案
Dec 10 #Javascript
关于react中组件通信的几种方式详解
Dec 10 #Javascript
vue项目中v-model父子组件通信的实现详解
Dec 10 #Javascript
Angular项目从新建、打包到nginx部署全过程记录
Dec 09 #Javascript
利用ES6实现单例模式及其应用详解
Dec 09 #Javascript
You might like
个人站长制做网页常用的php代码
2007/03/03 PHP
PHP中使用memcache存储session的三种配置方法
2014/04/05 PHP
使用PHP处理数据库数据如何将数据返回客户端并显示当前状态
2016/02/16 PHP
Smarty模板引擎缓存机制详解
2016/05/23 PHP
php制作圆形用户头像的实例_自定义封装类源代码
2017/09/18 PHP
用js做一个小游戏平台 (一)
2009/12/29 Javascript
JQuery从头学起第三讲
2010/07/06 Javascript
js下将字符串当函数执行的方法
2011/07/13 Javascript
jquery事件机制扩展插件 jquery鼠标右键事件。
2011/12/26 Javascript
jquery表格内容筛选实现思路及代码
2013/04/16 Javascript
javaScript中with函数用法实例分析
2015/06/08 Javascript
js格式化时间的简单实例
2016/11/27 Javascript
jQuery中animate的几种用法与注意事项
2016/12/12 Javascript
JavaScript 字符串数字左补位,右补位,取固定长度,截位扩展函数代码
2017/03/25 Javascript
JS闭包用法实例分析
2017/03/27 Javascript
AngularJS+bootstrap实现动态选择商品功能示例
2017/05/17 Javascript
vue2.0 和 animate.css的结合使用
2017/12/12 Javascript
AngularJS基于http请求实现下载php生成的excel文件功能示例
2018/01/23 Javascript
vue-baidu-map 进入页面自动定位的解决方案(推荐)
2018/04/28 Javascript
详解React-Router中Url参数改变页面不刷新的解决办法
2018/05/08 Javascript
微信小程序在地图选择地址并返回经纬度简单示例
2018/12/03 Javascript
Vue的路由及路由钩子函数的实现
2019/07/02 Javascript
node.js +mongdb实现登录功能
2020/06/18 Javascript
浅谈Matplotlib简介和pyplot的简单使用——文本标注和箭头
2018/01/09 Python
Python程序员面试题 你必须提前准备!(答案及解析)
2018/01/23 Python
Django 用户认证组件使用详解
2019/07/23 Python
日本面向世界,国际级的免税在线购物商城:DOKODEMO
2017/02/01 全球购物
生物有机护肤品:Aurelia Probiotic Skincare
2018/01/31 全球购物
大学生四年生活自我鉴定
2013/11/21 职场文书
电气工程及自动化专业自荐书范文
2013/12/18 职场文书
《三个小伙伴》教学反思
2014/04/11 职场文书
民主生活会发言材料
2014/10/20 职场文书
2014年招生工作总结
2014/11/26 职场文书
信访工作个人总结
2015/03/03 职场文书
公司车辆管理制度
2015/08/04 职场文书
教导处教学工作总结
2015/08/12 职场文书