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 相关文章推荐
window.open被浏览器拦截后的自定义提示效果代码
Nov 19 Javascript
JavaScript 基于原型的对象(创建、调用)
Oct 16 Javascript
Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结
Nov 14 Javascript
js判断60秒以及倒计时示例代码
Jan 24 Javascript
Javascript实现简单二级下拉菜单实例
Jun 15 Javascript
浅析JS动态创建元素【两种方法】
Apr 20 Javascript
强大Vue.js组件浅析
Sep 12 Javascript
javascript判断一个变量是数组还是对象
Apr 10 Javascript
微信小程序云开发之使用云数据库
May 17 Javascript
小程序click-scroll组件设计
Jun 18 Javascript
JS中==、===你分清楚了吗
Mar 04 Javascript
jQuery实现鼠标放置名字上显示详细内容气泡提示框效果的方法分析
Apr 04 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.MVC的模板标签系统(一)
2006/09/05 PHP
php 删除cookie和浏览器重定向
2009/03/16 PHP
详解PHP中的序列化、反序列化操作
2017/03/21 PHP
PHP合并两个或多个数组的方法
2019/01/20 PHP
laravel框架中表单请求类型和CSRF防护实例分析
2019/11/23 PHP
ExtJS 简介 让你知道extjs是什么
2008/12/29 Javascript
JS小框架 fly javascript framework
2009/11/26 Javascript
JQuery动画和停止动画实例代码
2013/03/01 Javascript
jquery和ajax的关系详细介绍
2013/11/29 Javascript
JavaScript数值数组排序示例分享
2014/05/27 Javascript
Javascript 实现复制(Copy)动作方法大全
2014/06/20 Javascript
JS实现清除指定cookies的方法
2014/09/20 Javascript
JavaScript设计模式之策略模式实例
2014/10/10 Javascript
JavaScript Function函数类型介绍
2015/04/08 Javascript
JavaScript实现鼠标滑过图片变换效果的方法
2015/04/16 Javascript
JavaScript快速切换繁体中文和简体中文的方法及网站支持简繁体切换的绝招
2016/03/07 Javascript
详解JavaScript对象类型
2016/06/16 Javascript
实现一个简单的vue无限加载指令方法
2017/01/10 Javascript
JavaScript中splice与slice的区别
2017/05/09 Javascript
vue绑定class与行间样式style详解
2017/08/16 Javascript
详解node Async/Await 更好的异步编程解决方案
2018/05/10 Javascript
使用js实现单链解决前端队列问题的方法
2020/02/03 Javascript
[38:54]完美世界DOTA2联赛PWL S2 Rebirth vs LBZS 第一场 11.28
2020/12/01 DOTA
Python网络爬虫项目:内容提取器的定义
2016/10/25 Python
使用python 的matplotlib 画轨道实例
2020/01/19 Python
Python模块 _winreg操作注册表
2020/02/05 Python
python3检查字典传入函数键是否齐全的实例
2020/06/05 Python
利用Python将多张图片合成视频的实现
2020/11/23 Python
Orvis官网:自1856年以来,优质服装、飞钓装备等
2018/12/17 全球购物
Watch Station官方网站:世界一流的手表和智能手表
2020/01/05 全球购物
Ooni英国官网:披萨烤箱
2020/05/31 全球购物
员工拾金不昧表扬信
2014/01/09 职场文书
员工辞职信怎么写
2015/02/27 职场文书
子女赡养老人协议书
2016/03/23 职场文书
2016年助残日旅游活动总结
2016/04/01 职场文书
Python 图片添加美颜效果
2022/04/28 Python