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

前端之家收集整理的这篇文章主要介绍了Angular自定义组件实现数据双向数据绑定的实例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

@H_301_0@学过Angular的同学都知道,输入框通过<font color="#000000"><font face="NSimsun">[(ngModel)]实现双向数据绑定,那么自定义组件能不能实现双向数据绑定呢?答案是肯定的。


@H_3010@<font color="#000000">Angular中,我们常常需要通过方括号<font face="NSimsun">[]和圆括号<font face="NSimsun">()实现组件间的交互:


@H
301_0@<font color="#000000">


@H_3010@那么在<font color="#000000"><font face="NSimsun">[]<font face="NSimsun">()的基础上,如何实现组件的双向数据绑定?


@H
3010@例子如下。


@H
301_0@

子组件:


<div class="jb51code">
<pre class="brush:xhtml;">

childStatus: {{childStatus}}

export class TestDataBindingComponent implements OnInit{
@Input() childStatus;
@Output() childStatusChange = new EventEmitter();
ngOnInit(){
setTimeout(()=>{
this.childStatus = false;
this.childStatusChange.emit(this.childStatus);
},5000);
}
}

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

@H_301_0@

父组件:

<test-binding [(childStatus)]="parentStatus">

parentStatus: {{parentStatus}}

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);
}
}

@H_301_0@在父组件我们初始化,并把它传到子组件

@H_301_0@设为,看它能不能传到父组件。再过5秒,我们在父组件将设为,看它能不能传到子组件。

@H_301_0@

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

@H_301_0@我们实现了双向绑定!

@H_301_0@查看本文代码效果,可点击

@H_
301_0@以上这篇Angular自定义组件实现数据双向数据绑定的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

猜你在找的JavaScript相关文章