angular2 父子组件数据传递之@Input和@Output详解
2017-12-26 10:41
288 查看
父组件向子组件传递数据
父组件传递数据到子组件通过@Input方式的现实方式
第一步:定义父组件
ParentComponent.ts
![](http://files.jb51.net/file_images/article/201707/20177584526079.png?20176584537)
(1).这里定义了两个类属性user和parent_data,
(2).一个
ParentComponent.html
![](http://files.jb51.net/file_images/article/201707/20177584552037.png?2017658460)
对应的页面:
![](http://files.jb51.net/file_images/article/201707/20177584926329.png?20176584933)
![](http://files.jb51.net/file_images/article/201707/20177585030873.png?20176585039)
![](http://files.jb51.net/file_images/article/201707/20177585054838.png?2017658512)
表单输入数据,点击页面上的按钮,调用页面
第二步:定义子组件:
ChildenComponent.ts
![](http://files.jb51.net/file_images/article/201707/20177585130891.png?20176585137)
![](http://files.jb51.net/file_images/article/201707/20177585147667.png?20176585155)
(1).这里定义了一个类属性data,并且用@Input装饰器修饰,修饰过后的data变量就具备接受父组件传过来的数据了,这里定义的data就是在页面接收父组件传递的data变量,看下面代码(2).还实现了一个onChanges接口,onChanges接口必须实现ngOnChanges方法,用来监控数据的变化,如果父组件的数据发生变化,我们这里就输出改变后的数据,父组件中表单输入的值发生变化,再点击按钮调用
下面我们看看效果
![](http://files.jb51.net/file_images/article/201707/20177585208532.png?20176585226)
子组件向父组件传递数据使用事件传递是子组件向父组件传递数据最常用的方式,子组件需要实例化EventEmitter类来订阅和触发自定义事件
第一步定义子组件
childenComponent.ts
![](http://files.jb51.net/file_images/article/201707/20177590544800.png?2017659556)
(1).实例化EventEmitter,赋值给event,event被@Output装饰器定义为输出属性,这样event具备了向上级传递数据的能力,通过调用EventEmitter类中定义的emit方法,来向上传递数据
(2).定义一个name属性,用于接受子组件页面的输入
(3).定义upward方法,用于子组件页面点击事件 触发事件调用,
childenComponent.html
![](http://files.jb51.net/file_images/article/201707/20177590612968.png?2017659619)
第二步定义父组件
parentComponent.ts
![](http://files.jb51.net/file_images/article/201707/20177590651532.png?2017659659)
parentComponent.html
![](http://files.jb51.net/file_images/article/201707/20177590709777.png?2017659716)
父组件通过绑定自定义事件event ,来订阅来自子组件触发事件(这里是点击事件),当我们点击子组件上面的按钮,调用子组件的
最终效果:表单输入数据,点击页面按钮,数据传递到父组件,在显示出来
![](http://files.jb51.net/file_images/article/201707/20177590732349.png?2017659751)
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
原文链接:http://www.jianshu.com/p/54d75ba76a21
父组件传递数据到子组件通过@Input方式的现实方式
第一步:定义父组件
ParentComponent.ts
![](http://files.jb51.net/file_images/article/201707/20177584526079.png?20176584537)
(1).这里定义了两个类属性user和parent_data,
(2).一个
next()方法,next方法用于将页面输入的数据赋值给parent_data属性
ParentComponent.html
![](http://files.jb51.net/file_images/article/201707/20177584552037.png?2017658460)
对应的页面:
![](http://files.jb51.net/file_images/article/201707/20177584926329.png?20176584933)
![](http://files.jb51.net/file_images/article/201707/20177585030873.png?20176585039)
![](http://files.jb51.net/file_images/article/201707/20177585054838.png?2017658512)
表单输入数据,点击页面上的按钮,调用页面
next()方法
next()方法内部将输入的数据user赋值给parent_data。parent_data获取到数据之后在模版中把获取到的值再赋给子组件中先前定义好的data变量到这里父组件就完成 类数据的传递,下面我们看看子组件怎么去接受这个值?
第二步:定义子组件:
ChildenComponent.ts
![](http://files.jb51.net/file_images/article/201707/20177585130891.png?20176585137)
![](http://files.jb51.net/file_images/article/201707/20177585147667.png?20176585155)
(1).这里定义了一个类属性data,并且用@Input装饰器修饰,修饰过后的data变量就具备接受父组件传过来的数据了,这里定义的data就是在页面接收父组件传递的data变量,看下面代码(2).还实现了一个onChanges接口,onChanges接口必须实现ngOnChanges方法,用来监控数据的变化,如果父组件的数据发生变化,我们这里就输出改变后的数据,父组件中表单输入的值发生变化,再点击按钮调用
next()方法,ngonChanges会检测到数据变化,
console.log(this.data)打印新的输出到控制台
下面我们看看效果
![](http://files.jb51.net/file_images/article/201707/20177585208532.png?20176585226)
子组件向父组件传递数据使用事件传递是子组件向父组件传递数据最常用的方式,子组件需要实例化EventEmitter类来订阅和触发自定义事件
第一步定义子组件
childenComponent.ts
![](http://files.jb51.net/file_images/article/201707/20177590544800.png?2017659556)
(1).实例化EventEmitter,赋值给event,event被@Output装饰器定义为输出属性,这样event具备了向上级传递数据的能力,通过调用EventEmitter类中定义的emit方法,来向上传递数据
(2).定义一个name属性,用于接受子组件页面的输入
(3).定义upward方法,用于子组件页面点击事件 触发事件调用,
upward()方法里面调用自定义事件event来触发emit方法 传递数据
childenComponent.html
![](http://files.jb51.net/file_images/article/201707/20177590612968.png?2017659619)
第二步定义父组件
parentComponent.ts
![](http://files.jb51.net/file_images/article/201707/20177590651532.png?2017659659)
parentComponent.html
![](http://files.jb51.net/file_images/article/201707/20177590709777.png?2017659716)
父组件通过绑定自定义事件event ,来订阅来自子组件触发事件(这里是点击事件),当我们点击子组件上面的按钮,调用子组件的
upward()方法,内部实现会调用
this.event.emit(this.name);传递数据,自此父组件就能够监听自定义事件event。调用getData来接收传递过来的数据
最终效果:表单输入数据,点击页面按钮,数据传递到父组件,在显示出来
![](http://files.jb51.net/file_images/article/201707/20177590732349.png?2017659751)
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
原文链接:http://www.jianshu.com/p/54d75ba76a21
相关文章推荐
- Angular 2父子组件数据传递之@Input和@Output详解 (上)
- Angular2父子组件之间数据传递:@Input和@Output (上)
- Angular2父子组件之间数据传递:@Input和@Output (下)
- Angular 2父子组件数据传递之@Input和@Output详解(下)
- angular2父子组件的数据传递,子组件向父组件抛出数据
- Angular 2父子组件数据传递之@ViewChild获取子组件详解
- Vue表单类的父子组件数据传递示例
- vue学习记录——父子组件间传递数据
- react都这么无情了,vue还是那么有义,4种父子组件数据双向传递大法
- angular2父子组件的数据传递,父组件向子组件传递数据
- Angular 2父子组件数据传递之局部变量获取子组件其他成员
- angularjs2中父子组件的数据传递的实例代码
- react(二)父子组件间的数据传递---prop
- Angular2 父子组件数据通信实例
- Vue4种父子组件数据双向传递
- vue.js 学习之组件之间数据传递详解
- vue组件中使用props传递数据的实例详解
- vuejs动态组件给子组件传递数据的方法详解
- vuejs父子组件之间数据交互详解
- 详解vue2父组件传递props异步数据到子组件的问题