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 相关文章推荐
JS中的异常处理方法分享
Dec 22 Javascript
jquery插件jquery倒计时插件分享
Dec 27 Javascript
浅谈JavaScript数据类型
Mar 03 Javascript
原生js结合html5制作小飞龙的简易跳球
Mar 30 Javascript
JS时间特效最常用的三款
Aug 19 Javascript
JS组件Bootstrap Table表格多行拖拽效果实现代码
Dec 08 Javascript
Vue.js常用指令汇总(v-if、v-for等)
Nov 03 Javascript
Javascript前端经典的面试题及答案
Mar 14 Javascript
angularjs实现过滤并替换关键字小功能
Sep 19 Javascript
安装Node.js并启动本地服务的操作教程
May 12 Javascript
JS无限级导航菜单实现方法
Jan 05 Javascript
微信小程序点击保存图片到本机功能
Dec 13 Javascript
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
收音机鉴频器对声音的影响和频偏分析
2021/03/02 无线电
php简单对象与数组的转换函数代码(php多层数组和对象的转换)
2011/05/18 PHP
php中session_unset与session_destroy的区别分析
2011/06/16 PHP
微信公众平台开发(五) 天气预报功能开发
2016/12/03 PHP
php libevent 功能与使用方法详解
2020/03/04 PHP
jquery()函数的三种语法介绍
2013/10/09 Javascript
jQuery读取和设定KindEditor值的方法
2013/11/22 Javascript
JS和JQUERY获取页面大小,滚动条位置,元素位置(示例代码)
2013/12/14 Javascript
node.js适合游戏后台开发吗?
2014/09/03 Javascript
javascript函数特点实例分析
2015/05/14 Javascript
详解参数传递四种形式
2015/07/21 Javascript
jQuery+CSS3实现3D立方体旋转效果
2015/11/10 Javascript
JS中解决谷歌浏览器记住密码输入框颜色改变功能
2017/02/13 Javascript
vue页面加载闪烁问题的解决方法
2018/03/28 Javascript
vue点击input弹出带搜索键盘并监听该元素的方法
2018/08/25 Javascript
@angular前端项目代码优化之构建Api Tree的方法
2018/12/24 Javascript
jQuery实现移动端图片上传预览组件的方法分析
2020/05/01 jQuery
解决vue prop传值default属性如何使用,为何不生效的问题
2020/09/21 Javascript
原生js实现移动小球(碰撞检测)
2020/12/17 Javascript
[02:34]DOTA2亚洲邀请赛 BG战队出场宣传片
2015/03/09 DOTA
[09:33]2015国际邀请赛第四日TOP10
2015/08/08 DOTA
[01:52]DOTA2完美大师赛Vega战队趣味视频——kpii老师小课堂
2017/11/25 DOTA
对python中的for循环和range内置函数详解
2018/04/17 Python
PyTorch读取Cifar数据集并显示图片的实例讲解
2018/07/27 Python
Python对接支付宝支付自实现功能
2019/10/10 Python
python中删除某个元素的方法解析
2019/11/05 Python
python算的上脚本语言吗
2020/06/22 Python
HTML5 Canvas的性能提高技巧经验分享
2013/07/02 HTML / CSS
Elemis美国官网:英国的第一豪华护肤品牌
2018/03/15 全球购物
酒店前台接待岗位职责
2013/12/03 职场文书
会计专业自我鉴定范文
2013/12/29 职场文书
计算机毕业大学生求职信
2014/06/26 职场文书
英语系本科生求职信
2014/07/15 职场文书
酒桌上的开场白
2015/06/01 职场文书
PostgreSQL数据库去除重复数据和运算符的基本查询操作
2022/04/12 PostgreSQL
java高级用法JNA强大的Memory和Pointer
2022/04/19 Java/Android