欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-05-14 19:45:46
前言 如今的前端开发,都朝组件式开发模式靠拢,如果使用目前最流行的前端框架angular和react开发应用,不可避免地需要开发组件,也就意味着我们需要考虑组件间的数据传...

前言

如今的前端开发,都朝组件式开发模式靠拢,如果使用目前最流行的前端框架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父子组件之间共享服务通信的实现

总结

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