学过Angular的同学都知道,输入框通过[(ngModel)]实现双向数据绑定,那么自定义组件能不能实现双向数据绑定呢?答案是肯定的。
Angular中,我们常常需要通过方括号[]和圆括号()实现组件间的交互:

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

  1. //testDataBinding.component.html
  2. <h1>childStatus: {{childStatus}}</h1>
  1. //testDataBinding.component.ts
  2. export class TestDataBindingComponent implements OnInit{
  3. @Input() childStatus;
  4. @Output() childStatusChange = new EventEmitter();
  5. ngOnInit(){
  6. setTimeout(()=>{
  7. this.childStatus = false;
  8. this.childStatusChange.emit(this.childStatus);
  9. },5000);
  10. }
  11. }

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

父组件:

  1. //app.component.html
  2. <test-binding [(childStatus)]="parentStatus"></test-binding>
  3. <h1>parentStatus: {{parentStatus}}</h1>
  1. //app.component.ts
  2. import { Component,OnInit } from '@angular/core';
  3. @Component({
  4. selector: 'my-app',
  5. templateUrl: './app.component.html',
  6. styleUrls: ['./app.component.css']
  7. })
  8. export class AppComponent implements OnInit{
  9. parentStatus: boolean = true;
  10. ngOnInit(){
  11. setTimeout(()=>{
  12. this.parentStatus = true;
  13. },10000);
  14. }
  15. }

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

事实证明,子组件值变化后,父组件的值也跟着变化;父组件值变化后子组件的值也跟着变了!
我们实现了双向绑定!
查看本文代码和效果,可点击这里

版权声明:本文为cme-kai原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:http://www.cnblogs.com/cme-kai/p/8012159.html