如何在 POST 之后刷新 angular2 中的可观察对象
How to refresh an observable in angular2 after a POST
我有一个 table 显示信息,点击 table 行后,用户可以更新值
他完成请求后,table 不会更新为新值,我必须按 F5 键刷新视图。
如何在完成请求后强制执行新的 get 请求
这里是相关代码
我的服务
import { Injectable } from '@angular/core';
import { Http, Response } from '@angular/http';
import {Observable} from 'rxjs/Rx';
import { BehaviorSubject } from 'rxjs/BehaviorSubject';
// Import RxJs required methods
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/catch';
import { Device } from '../model/Device';
@Injectable()
export class DeviceService {
devices$: BehaviorSubject<Device[]>;
constructor(private http : Http) {
this.initializeDevices();
}
initializeDevices() {
var url = "./api/read/network/device";
//var url = '../assets/data/devices.json';
if (!this.devices$) {
this.devices$ = <BehaviorSubject<Device[]>> new BehaviorSubject(new Array<Device>());
this.http.get(url)
.map((res:Response) => res.json())
.subscribe(devices => {
this.devices$.next(devices);
});
}
}
subscribeToDevices(): Observable<Device[]> {
return this.devices$.asObservable();
}
}
我的组件
import { Component, OnInit, ViewChild } from '@angular/core';
import { DeviceService } from '../../services/device.service';
import { MacService } from '../../services/mac.service';
import { Device } from '../../model/Device';
@Component({
selector: 'app-device-table',
templateUrl: './device-table.component.html',
styleUrls: ['./device-table.component.sass']
})
export class DeviceTableComponent implements OnInit {
devices;
//reference to the datatable needed to count filtered rows
@ViewChild
('dt') dt;
constructor(private deviceService : DeviceService, private macService : MacService) { }
ngOnInit() {
this.registerEvents();
this.getDevices();
}
getDevices(){
this.deviceService.subscribeToDevices().subscribe(
devices => this.processDevices(devices),
error => console.log(error)
);
}
processDevices(devices){
//just data manipulation
}
emitShowDialogEvent(device) {
if(!device.macAddress) {
return;
}
this.macService.broadcastShowDialogEvent(device.macAddress);
}
registerEvents(){
this.macService.dataChangedEvent.subscribe(event =>{
console.log('data changed event');
this.getDevices(); //not provoking a new GET request to the API :(
});
}
}
我有另一个组件 MACService,它在发送 POST 请求时发出一个事件,该事件被捕获为 dataChangedEvent
您可以使用两种方式。
一个是在 POST 订阅事件中调用 GET 请求。
this.guardianService.editGuardian(this.guardData).subscribe(res=> {
this.loadData(); // this is function who makes GET request
});
另一种方法是使用 ReplaySubject。
private subject: Subject<any> = new ReplaySubject<any>(1);
get $getSubject(): Observable<any> {
return this.subject.asObservable();
}
loadData() {
this._http.get(url, header)
.map(x=>x.json())
.subscribe(data=> {
this.subject.next(data);
});
}
postData(data) .....
这是服务。
这里是 component
this.serviceHandle.$getSubject.subscribe(res => {
//here goes any thing you want to do.
});
this.serviceHandle.loadData(); // this function will make reqeust
this._accountService.editAccountData(account).subscribe(res=> {
this.serviceHandle.loadData();
});
我有一个 table 显示信息,点击 table 行后,用户可以更新值 他完成请求后,table 不会更新为新值,我必须按 F5 键刷新视图。
如何在完成请求后强制执行新的 get 请求
这里是相关代码
我的服务
import { Injectable } from '@angular/core';
import { Http, Response } from '@angular/http';
import {Observable} from 'rxjs/Rx';
import { BehaviorSubject } from 'rxjs/BehaviorSubject';
// Import RxJs required methods
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/catch';
import { Device } from '../model/Device';
@Injectable()
export class DeviceService {
devices$: BehaviorSubject<Device[]>;
constructor(private http : Http) {
this.initializeDevices();
}
initializeDevices() {
var url = "./api/read/network/device";
//var url = '../assets/data/devices.json';
if (!this.devices$) {
this.devices$ = <BehaviorSubject<Device[]>> new BehaviorSubject(new Array<Device>());
this.http.get(url)
.map((res:Response) => res.json())
.subscribe(devices => {
this.devices$.next(devices);
});
}
}
subscribeToDevices(): Observable<Device[]> {
return this.devices$.asObservable();
}
}
我的组件
import { Component, OnInit, ViewChild } from '@angular/core';
import { DeviceService } from '../../services/device.service';
import { MacService } from '../../services/mac.service';
import { Device } from '../../model/Device';
@Component({
selector: 'app-device-table',
templateUrl: './device-table.component.html',
styleUrls: ['./device-table.component.sass']
})
export class DeviceTableComponent implements OnInit {
devices;
//reference to the datatable needed to count filtered rows
@ViewChild
('dt') dt;
constructor(private deviceService : DeviceService, private macService : MacService) { }
ngOnInit() {
this.registerEvents();
this.getDevices();
}
getDevices(){
this.deviceService.subscribeToDevices().subscribe(
devices => this.processDevices(devices),
error => console.log(error)
);
}
processDevices(devices){
//just data manipulation
}
emitShowDialogEvent(device) {
if(!device.macAddress) {
return;
}
this.macService.broadcastShowDialogEvent(device.macAddress);
}
registerEvents(){
this.macService.dataChangedEvent.subscribe(event =>{
console.log('data changed event');
this.getDevices(); //not provoking a new GET request to the API :(
});
}
}
我有另一个组件 MACService,它在发送 POST 请求时发出一个事件,该事件被捕获为 dataChangedEvent
您可以使用两种方式。
一个是在 POST 订阅事件中调用 GET 请求。
this.guardianService.editGuardian(this.guardData).subscribe(res=> {
this.loadData(); // this is function who makes GET request
});
另一种方法是使用 ReplaySubject。
private subject: Subject<any> = new ReplaySubject<any>(1);
get $getSubject(): Observable<any> {
return this.subject.asObservable();
}
loadData() {
this._http.get(url, header)
.map(x=>x.json())
.subscribe(data=> {
this.subject.next(data);
});
}
postData(data) .....
这是服务。 这里是 component
this.serviceHandle.$getSubject.subscribe(res => {
//here goes any thing you want to do.
});
this.serviceHandle.loadData(); // this function will make reqeust
this._accountService.editAccountData(account).subscribe(res=> {
this.serviceHandle.loadData();
});