Angular自定义组件实现数据双向绑定
学过Angular的同学都知道,输入框通过[(ngModel)]
实现双向数据绑定,那么自定义组件能不能实现双向数据绑定呢?答案是肯定的。
Angular中,我们常常需要通过方括号[]
和圆括号()
实现组件间的交互:
文章图片
binding.png
那么在
[]
和
()
的基础上,如何实现组件的双向数据绑定?
例子如下。
子组件:
//testDataBinding.component.htmlchildStatus: {{childStatus}}
//testDataBinding.component.tsexport class TestDataBindingComponent implements OnInit{
@Input() childStatus;
@Output() childStatusChange = new EventEmitter();
ngOnInit(){
setTimeout(()=>{
this.childStatus = false;
this.childStatusChange.emit(this.childStatus);
},5000);
}
}
【Angular自定义组件实现数据双向绑定】注意这里的写法,这是关键所在,输出属性前半部分必须与输入属性相同,输入属性可以随意取名,输出属性需在输入属性基础上加上
Change
,比如你的输入属性是myData
,那么输出属性就必须是myDataChange
。父组件:
//app.component.html
parentStatus: {{parentStatus}}
//app.component.tsimport { 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
,看它能不能传到子组件。文章图片
test.gif
事实证明,子组件值变化后,父组件的值也跟着变化;父组件值变化后子组件的值也跟着变了!
我们实现了双向绑定!
查看本文代码和效果,可点击 这里。
推荐阅读
- SpringBoot调用公共模块的自定义注解失效的解决
- python自定义封装带颜色的logging模块
- angular2内置管道
- 列出所有自定义的function和view
- 动态组件与v-once指令
- vue组件中为何data必须是一个函数()
- (六)Component初识组件
- Spring|Spring Boot 自动配置的原理、核心注解以及利用自动配置实现了自定义 Starter 组件
- vuex|vuex 基础结构
- 自定义MyAdapter