angular4 共享服务在多个组件中数据通信的示例


Posted in Javascript onMarch 30, 2018

应用场景,不同组件中操作统一组数据,不论哪个组件对数据进行了操作,其他组件中立马看到效果。这样他们就要共用一个服务实例,是本次的重点,如果不同实例,那么操作的就不是同一组数据,那么就不会有这样的效果,想实现共用服务实例,就是在所有父组件中priviates:[]中引入这个组件,子组件中不需要再次引入,那么他们都是用的父组件中的服务实例。

1、公用服务

import {Injectable} from "@angular/core";

@Injectable()
export class CommonService {
 public dateList: any = [
 {
  name: "张旭超",
  age: 20,
  address: "北京市朝阳区"
 }
 ];

 constructor() {

 }

 addDateFun(data) {
 this.dateList.push(data);
 }
}

2、parent.component.ts

import {Component, OnInit} from "@angular/core";
import {CommonService} from "./common.service";

// 这里要通过父子公用服务来操作数据,只需要在父组件中引入服务。
@Component({
 selector: "parent-tag",
 templateUrl: "parent.component.html",
 providers: [
 CommonService
 ]
})
export class ParentComponent implements OnInit {
 public list: any = [];

 constructor(private commonService: CommonService) {
 this.list = commonService.dateList;
 }

 ngOnInit() {

 }
}

3、parent.component.html

<table width="500">
 <tr *ngFor="let item of list">
 <td>
  {{item.name}}
 </td>
 <td>
  {{item.age}}
 </td>
 <td>
  {{item.address}}
 </td>
 </tr>
</table>
<child-one-tag></child-one-tag>

4、child-one.component.ts

import {Component} from "@angular/core";
import {CommonService} from "./common.service";

@Component({
 selector: "child-one-tag",
 templateUrl: "child-one.component.html"
})
export class ChildOneComponent {
 public display: boolean = false;
 public username: string = "";
 public age: number = 20;
 public address: string = "";
 constructor(public commonService: CommonService) {

 }

 showDialog() {
 this.display = true;
 }

 hideDialog() {
 this.display = false;
 }

 addInfoFun() {
 let params = {
  name: this.username,
  age: this.age,
  address: this.address
 };
 this.commonService.addDateFun(params);
 params = {};
 }
}

5、child-one.component.html

<p-dialog header="弹窗" [(visible)]="display" [width]="300" appendTo="body" modal="modal">
 <form #myForm="ngForm" name="myForm">
 <p>姓名:<input type="text" name="username" [(ngModel)]="username" pInputText/></p>
 <p>年龄:<input type="number" name="age" [(ngModel)]="age" pInputText/></p>
 <p>地址:<input type="text" name="address" [(ngModel)]="address" pInputText/></p>
 <button pButton label="确定" type="submit" (click)="addInfoFun()"></button>
 <button pButton label="取消" (click)="hideDialog()"></button>
 </form>
</p-dialog>
<button label="添加" pButton (click)="showDialog()"></button>

angular4 共享服务在多个组件中数据通信的示例

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript之HTMLCollection接口代码
Apr 27 Javascript
jQuery页面滚动浮动层智能定位实例代码
Aug 23 Javascript
用JavaScript实现类似于ListBox功能示例代码
Mar 09 Javascript
jQuery的deferred对象详解
Nov 12 Javascript
JS+CSS实现模仿浏览器网页字符查找功能的方法
Feb 26 Javascript
jQuery中animate用法实例分析
Mar 09 Javascript
AngularJS删除路由中的#符号的方法
Sep 20 Javascript
jQuery实现下拉菜单的实例代码
Jun 19 jQuery
Iphone手机、安卓手机浏览器控制默认缩放大小的方法总结(附代码)
Aug 18 Javascript
react-native DatePicker日期选择组件的实现代码
Sep 12 Javascript
layui监听单元格编辑前后交互的例子
Sep 16 Javascript
Node.js HTTP服务器中的文件、图片上传的方法
Sep 23 Javascript
js将键值对字符串转为json字符串的方法
Mar 30 #Javascript
webpack4.0打包优化策略整理小结
Mar 30 #Javascript
Angular4学习笔记router的简单使用
Mar 30 #Javascript
vue.js中created方法作用
Mar 30 #Javascript
微信小程序实现全局搜索代码高亮的示例
Mar 30 #Javascript
json对象及数组键值的深度大小写转换问题详解
Mar 30 #Javascript
Vue实现导出excel表格功能
Mar 30 #Javascript
You might like
兼容性比较好的PHP生成缩略图的代码
2011/01/12 PHP
使用PHPMailer实现邮件发送代码分享
2014/10/23 PHP
PHP chunk_split()函数讲解
2019/02/12 PHP
php统计数组不同元素的个数的实例方法
2019/09/26 PHP
jquery live()调用不存在的解决方法
2014/02/26 Javascript
jQuery绑定事件不执行但alert后可以正常执行
2014/06/03 Javascript
轻松创建nodejs服务器(8):非阻塞是如何实现的
2014/12/18 NodeJs
JS+CSS实现自动改变切换方向图片幻灯切换效果的方法
2015/03/02 Javascript
深入解析JavaScript编程中的this关键字使用
2015/11/09 Javascript
jQuery获取select选中的option的value值实现方法
2016/08/29 Javascript
基于jQuery实现定位导航位置效果
2017/11/15 jQuery
jQuery的Ajax接收java返回数据方法
2018/08/11 jQuery
js图片无缝滚动插件使用详解
2020/05/26 Javascript
使用layer弹窗提交表单时判断表单是否输入为空的例子
2019/09/26 Javascript
深入分析JavaScript 事件循环(Event Loop)
2020/06/19 Javascript
[55:47]DOTA2上海特级锦标赛C组小组赛#2 LGD VS Newbee第三局
2016/02/27 DOTA
Python实现的多线程端口扫描工具分享
2015/01/21 Python
利用Python脚本实现ping百度和google的方法
2017/01/24 Python
python之Character string(实例讲解)
2017/09/25 Python
PyQt5每天必学之滑块控件QSlider
2018/04/20 Python
python实现画一颗树和一片森林
2018/06/25 Python
python中时间模块的基本使用教程
2019/05/14 Python
Django+zTree构建组织架构树的方法
2019/08/21 Python
用python的turtle模块实现给女票画个小心心
2019/11/23 Python
python——全排列数的生成方式
2020/02/26 Python
欧洲最大的滑雪假期供应商之一:Sunweb Holidays
2018/01/06 全球购物
如果让你测试一台高速激光打印机,你都会进行哪些测试
2012/12/04 面试题
Java面试题汇总
2015/12/06 面试题
工程现场管理求职自荐信
2013/10/02 职场文书
大专毕业生自我鉴定
2013/11/21 职场文书
网络编辑求职信
2014/04/30 职场文书
园林专业毕业生自荐信
2014/07/04 职场文书
就业协议书
2014/09/12 职场文书
井冈山红色之旅心得体会
2014/10/07 职场文书
基于nginx实现上游服务器动态自动上下线无需reload的实现方法
2021/03/31 Servers
Vue如何实现组件间通信
2021/05/15 Vue.js