源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2022-08-31 04:40 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Angular 2父子组件之间共享服务通信的实现
[b]前言[/b] 如今的前端开发,都朝组件式开发模式靠拢,如果使用目前最流行的前端框架Angular和React开发应用,不可避免地需要开发组件,也就意味着我们需要考虑组件间的数据传递等问题,不过Angular 2已经为我们提供了很好的解决方案。 本文详细介绍了Angular2父子组件共享服务通信的相关内容,父子组件共享同一个服务,利用该服务实现双向通信,下面来看看详细的介绍: [b]第一步:定义服务[/b] parentService.ts [img]http://files.jb51.net/file_images/article/201707/201774105347406.png?201764105355[/img] 1).这里用Injectable修饰这个类是一个服务,在其他用到地方只需要注入使用 (2).我们还定义了一个name变量并且初始化值,和一个公共的方法getData parent.module.ts [img]http://files.jb51.net/file_images/article/201707/201774105411205.png?201764105419[/img] 我们这里把刚才创建的parentService服务依赖加进来,接着在provides中注册这个parentService服务,在ParentModule模块中注册之后,对于父组件和子组件来说都是指向同一个服务实例,而且这个服务的作用域只在当前这个模块中有效,这句话理解了,就等于理解了父子组件共享服务实现数据通信 [b]在父组件中使用服务[/b] parent.component.ts [img]http://files.jb51.net/file_images/article/201707/201774105442928.png?201764105449[/img] 导入parentService服务,在构造函数中声明注入parentService服务,因为我们在parentModule模块中,已经将parentService 通过provides注册过,所以我们在组件中不需要进行注册,直接可以使用,你可以这样理解,把当它想象成在模块的容器中已经存在了,只需要从容器中拿出来使用。 (1).这里我们定义了一个[code]OnClick()[/code]方法,当页面点击事件触发,就会来调用parentService服务定义的方法[code]getData()[/code]获取返回值,弹出返回值。 对应的父组件模版 [img]http://files.jb51.net/file_images/article/201707/201774105623338.png?201764105631[/img] [b]在子组件中使用服务[/b] 因为共享的是同一个ParentService服务实例,所以我们在子组件中也可以调用个ParentService服务的方法,代码同上面用一样 childen.component.ts [img]http://files.jb51.net/file_images/article/201707/201774105648765.png?201764105656[/img]   这里同样定义了一个方法,用于测试调用parentService服务,代码实现跟上面一样,不在描述, 对应的子组件模版 [img]http://files.jb51.net/file_images/article/201707/201774105725522.png?201764105733[/img]   最终效果: [img]http://files.jb51.net/file_images/article/201707/201774105846329.png?201764105853[/img] [b]总结[/b] 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程素材网的支持。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部