Angular 2父子组件之间共享服务通信的实现


Posted in Javascript onJuly 04, 2017

前言

如今的前端开发,都朝组件式开发模式靠拢,如果使用目前最流行的前端框架Angular和React开发应用,不可避免地需要开发组件,也就意味着我们需要考虑组件间的数据传递等问题,不过Angular 2已经为我们提供了很好的解决方案。

本文详细介绍了Angular2父子组件共享服务通信的相关内容,父子组件共享同一个服务,利用该服务实现双向通信,下面来看看详细的介绍:

第一步:定义服务

parentService.ts

Angular 2父子组件之间共享服务通信的实现

1).这里用Injectable修饰这个类是一个服务,在其他用到地方只需要注入使用

(2).我们还定义了一个name变量并且初始化值,和一个公共的方法getData

parent.module.ts

Angular 2父子组件之间共享服务通信的实现

我们这里把刚才创建的parentService服务依赖加进来,接着在provides中注册这个parentService服务,在ParentModule模块中注册之后,对于父组件和子组件来说都是指向同一个服务实例,而且这个服务的作用域只在当前这个模块中有效,这句话理解了,就等于理解了父子组件共享服务实现数据通信

在父组件中使用服务

parent.component.ts

Angular 2父子组件之间共享服务通信的实现

导入parentService服务,在构造函数中声明注入parentService服务,因为我们在parentModule模块中,已经将parentService 通过provides注册过,所以我们在组件中不需要进行注册,直接可以使用,你可以这样理解,把当它想象成在模块的容器中已经存在了,只需要从容器中拿出来使用。

(1).这里我们定义了一个OnClick()方法,当页面点击事件触发,就会来调用parentService服务定义的方法getData()获取返回值,弹出返回值。

对应的父组件模版

Angular 2父子组件之间共享服务通信的实现

在子组件中使用服务

因为共享的是同一个ParentService服务实例,所以我们在子组件中也可以调用个ParentService服务的方法,代码同上面用一样

childen.component.ts

Angular 2父子组件之间共享服务通信的实现 

这里同样定义了一个方法,用于测试调用parentService服务,代码实现跟上面一样,不在描述,

对应的子组件模版

Angular 2父子组件之间共享服务通信的实现 

最终效果:

Angular 2父子组件之间共享服务通信的实现

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
javascript 简练的几个函数
Aug 29 Javascript
jQuery 点击图片跳转上一张或下一张功能的实现代码
Mar 12 Javascript
jQuery.getScript加载同域JS的代码
Feb 13 Javascript
Javascript的&&和||的另类用法
Jul 23 Javascript
详解JavaScript中的Unescape()和String() 函数
Nov 09 Javascript
js实现简单的碰壁反弹效果
Aug 30 Javascript
jQuery EasyUI 获取tabs的实例解析
Dec 06 Javascript
vue-router相关基础知识及工作原理
Mar 16 Javascript
vue 自定义 select内置组件
Apr 10 Javascript
详解VUE调用本地json的使用方法
May 15 Javascript
使用JS判断页面是首次被加载还是刷新
May 26 Javascript
layui的面包屑或者表单不显示的解决方法
Sep 05 Javascript
jQuery实现动态给table赋值的方法示例
Jul 04 #jQuery
Angular 2父子组件数据传递之局部变量获取子组件其他成员
Jul 04 #Javascript
Angular 4.X开发实践中的踩坑小结
Jul 04 #Javascript
jQuery操作DOM_动力节点Java学院整理
Jul 04 #jQuery
jQuery层级选择器_动力节点节点Java学院整理
Jul 04 #jQuery
jQuery简介_动力节点Java学院整理
Jul 04 #jQuery
JS实现给json数组动态赋值的方法示例
Mar 19 #Javascript
You might like
Discuz! 5.0.0论坛程序中加入一段js代码,让会员点击下载附件前自动弹出提示窗口
2007/04/18 PHP
简单的php 验证图片生成函数
2009/05/21 PHP
Yii中CGridView关联表搜索排序方法实例详解
2014/12/03 PHP
基于jquery实现漂亮的动态信息提示效果
2011/08/02 Javascript
javascript控制swfObject应用介绍
2012/11/29 Javascript
jQuery 选择表格(table)里的行和列及改变简单样式
2012/12/15 Javascript
js为数字添加逗号并格式化数字的代码
2013/08/23 Javascript
jquery sortable的拖动方法示例详解
2014/01/16 Javascript
jQuery使用经验小技巧(推荐)
2016/05/31 Javascript
NodeJS基础API搭建服务器详细过程记录
2017/04/01 NodeJs
微信小程序实现图片轮播及文件上传
2017/04/07 Javascript
浅谈angular2 组件的生命周期钩子
2017/08/12 Javascript
JS实现的小火箭发射动画效果示例
2018/12/08 Javascript
用Node写一条配置环境的指令
2019/11/14 Javascript
python实现的阳历转阴历(农历)算法
2014/04/25 Python
python网络编程学习笔记(四):域名系统
2014/06/09 Python
Python模拟百度登录实例详解
2016/01/20 Python
Python做文本按行去重的实现方法
2016/10/19 Python
pytorch + visdom CNN处理自建图片数据集的方法
2018/06/04 Python
Python拼接微信好友头像大图的实现方法
2018/08/01 Python
python中嵌套函数的实操步骤
2019/02/27 Python
详解PyCharm+QTDesigner+PyUIC使用教程
2019/06/13 Python
DataFrame.to_excel多次写入不同Sheet的实例
2019/12/02 Python
完美解决keras 读取多个hdf5文件进行训练的问题
2020/07/01 Python
Pycharm如何自动生成头文件注释
2020/11/14 Python
python openpyxl模块的使用详解
2021/02/25 Python
浅谈CSS3特性查询(Feature Query: @supports)功能简介
2017/07/31 HTML / CSS
马歇尔耳机官网:Marshall Headphones
2020/02/04 全球购物
JPA的优势都有哪些
2013/07/04 面试题
公关关系专员的自我评价分享
2013/11/20 职场文书
工商企业管理专业自荐信范文
2014/04/12 职场文书
小学生纪律委员竞选稿
2015/11/19 职场文书
辞职信怎么写?你都知道吗?
2019/06/24 职场文书
python基于tkinter制作无损音乐下载工具
2021/03/29 Python
Python中Permission denied的解决方案
2021/04/02 Python
Win11快速关闭所有广告推荐
2022/04/19 数码科技