在Angular中如何实现双向数据绑定
程序员文章站
2022-04-21 13:06:58
...
下面小编就为大家分享一篇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中如何实现双向数据绑定的详细内容,更多请关注其它相关文章!
上一篇: 在WebStorm中添加Vue.js单文件组件的高亮及语法支持实例
下一篇:
正则匹配 标签
推荐阅读
-
.NET Core WebApi中如何实现多态数据绑定实例代码
-
只打印指定数据区域在Excel中如何实现局部数据CTRL+P打印
-
.NET Core WebApi中如何实现多态数据绑定实例代码
-
详解如何在Vue2中实现组件props双向绑定
-
Angular和Vue双向数据绑定的实现原理(重点是vue的双向绑定)
-
解决angular2在双向数据绑定时[(ngModel)]无法使用的问题
-
angular4自定义组件非input元素实现ngModel双向数据绑定的方法
-
自定义Angular指令与jQuery实现的Bootstrap风格数据双向绑定的单选与多选下拉框
-
详解Angular中实现自定义组件的双向绑定的两种方法
-
浅谈vue中数据双向绑定的实现原理