这篇文章主要为大家展示了“Angular 2父子组件数据传递之@Input和@Output有什么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Angular 2父子组件数据传递之@Input和@Output有什么用”这篇文章吧。
Angular 提供了@Input和@Output语法来处理组件数据的流入流出,接下来我们通过@Input和@Output来演示父子组建之间的数据传递
父组件向子组件传递数据
父组件传递数据到子组件通过@Input方式的现实方式
第一步:定义父组件
ParentComponent.ts
(1).这里定义了两个类属性user和parent_data,
(2).一个next()
方法,next方法用于将页面输入的数据赋值给parent_data属性
ParentComponent.html
对应的页面:
表单输入数据,点击页面上的按钮,调用页面next()
方法
next()
方法内部将输入的数据user赋值给parent_data。parent_data获取到数据之后在模版中把获取到的值再赋给子组件中先前定义好的data变量到这里父组件就完成 类数据的传递,下面我们看看子组件怎么去接受这个值?
第二步:定义子组件:
ChildenComponent.ts
(1).这里定义了一个类属性data,并且用@Input装饰器修饰,修饰过后的data变量就具备接受父组件传过来的数据了,这里定义的data就是在页面接收父组件传递的data变量,看下面代码(2).还实现了一个onChanges接口,onChanges接口必须实现ngOnChanges方法,用来监控数据的变化,如果父组件的数据发生变化,我们这里就输出改变后的数据,父组件中表单输入的值发生变化,再点击按钮调用next()
方法,ngonChanges会检测到数据变化, console.log(this.data)
打印新的输出到控制台
下面我们看看效果
以上是“Angular 2父子组件数据传递之@Input和@Output有什么用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注天达云行业资讯频道!