在Angular 7中,可以使用服务(service)来实现两个组件之间的数据共享。以下是一个具体的解决方法,包含代码示例:
import { Injectable } from '@angular/core';
import { BehaviorSubject } from 'rxjs';
@Injectable()
export class SharedService {
private data = new BehaviorSubject(''); // 初始值为空字符串
currentData = this.data.asObservable();
constructor() { }
updateData(newData: string) {
this.data.next(newData);
}
}
import { Component } from '@angular/core';
import { SharedService } from './shared.service';
@Component({
selector: 'app-component-a',
template: `
`
})
export class ComponentA {
data: string;
constructor(private sharedService: SharedService) { }
updateSharedData() {
this.sharedService.updateData(this.data);
}
}
import { Component } from '@angular/core';
import { SharedService } from './shared.service';
@Component({
selector: 'app-component-b',
template: `
Shared Data: {{ sharedData }}
`
})
export class ComponentB {
sharedData: string;
constructor(private sharedService: SharedService) {
this.sharedService.currentData.subscribe(data => {
this.sharedData = data;
});
}
}
通过以上步骤,组件A可以更新数据并将其传递给数据共享服务,而组件B可以订阅数据共享服务以获取最新的共享数据。
请注意,在使用此方法时,需要将SharedService提供给应用的根模块(AppModule)中的providers数组:
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { ComponentA } from './component-a.component';
import { ComponentB } from './component-b.component';
import { SharedService } from './shared.service';
@NgModule({
imports: [BrowserModule],
declarations: [AppComponent, ComponentA, ComponentB],
providers: [SharedService],
bootstrap: [AppComponent]
})
export class AppModule { }
这样,Angular就可以正确地注入共享服务并在组件A和组件B之间共享数据了。