使用共享服务:
服务:
@Injectable() export class MyService { myMethod$: Observable<any>; private myMethodSubject = new Subject<any>(); constructor() { this.myMethod$= this.myMethodSubject.asObservable(); } myMethod(data) { console.log(data); // I have data! Let's return it so subscribers can use it! // we can do stuff with data if we want this.myMethodSubject.next(data); } }
Component1(发件人):
export class SomeComponent { public data: Array<any> = MyData; public constructor(private myService: MyService) { this.myService.myMethod(this.data); } }
Component2(接收器):
export class SomeComponent2 { public data = {}; public constructor(private myService: MyService) { this.myService.myMethod$.subscribe((data) => { this.data = data; // And he have data here too! } ); } }
原文地址:https://www.jb51.cc/angularjs/140882.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。