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

网友投稿 381 2023-03-07


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

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

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

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

例子如下。

子组件:

//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.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,看它能不能传到子组件。

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

我们实现了双向绑定!

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


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:SpringBoot配置SwaggerUI访问404错误的解决方法
下一篇:Java核心库实现AOP过程
相关文章

 发表评论

暂时没有评论,来抢沙发吧~