Angular自定义组件实现数据双向数据绑定的实例
学过Angular的同学都知道,输入框通过[(ngModel)]
实现双向数据绑定,那么自定义组件能不能实现双向数据绑定呢?答案是肯定的。
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); } }
在父组件我们初始化parentStatus
为true
,并把它传到子组件TestDataBindingComponent
。
在子组件里,5秒后我们把childStatus
设为false
,看它能不能传到父组件。再过5秒,我们在父组件将parentStatus
设为true
,看它能不能传到子组件。
事实证明,子组件值变化后,父组件的值也跟着变化;父组件值变化后子组件的值也跟着变了!
我们实现了双向绑定!
查看本文代码和效果,可点击这里。
以上这篇Angular自定义组件实现数据双向数据绑定的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
举例详解AngularJS中ngShow和ngHide的使用方法
这篇文章主要介绍了举例详解AngularJS中ngShow和ngHide的使用方法,AngularJS是一款非常热门的JavaScript框架,需要的朋友可以参考下2015-06-06Angular实现类似博客评论的递归显示及获取回复评论的数据
这篇文章主要给大家介绍了关于Angular如何实现类似博客评论的递归显示及获取回复评论的数据的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。2017-11-11后端接收不到AngularJs中$http.post发送的数据原因分析及解决办法
这篇文章主要介绍了后端接收不到AngularJs中$http.post发送的数据原因分析及解决办法的相关资料,需要的朋友可以参考下2016-07-07Angular 理解module和injector,即依赖注入
本文主要介绍Angular 理解module和injector的知识,这里整理了相关知识,并详细介绍了依赖注入的问题,有兴趣的小伙伴可以参考下2016-09-09Angular 4依赖注入学习教程之Injectable装饰器(六)
这篇文章主要给大家介绍了关于Angular 4依赖注入之Injectable装饰器的相关资料,文中介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面来跟着小编一起学习学习吧。2017-06-06
最新评论