使用异步管道时无法读取未定义的 属性 'next'
Cannot read property 'next' of undefined when using async pipe
我有这样的服务,它模拟了一个 API 调用,
import { Injectable } from '@angular/core';
import { Observable, Subscriber} from 'rxjs';
import { DeviceStatus } from '../models/device-status-model';
@Injectable()
export class GetStatusService {
public deviceStatusObserver: Subscriber<DeviceStatus>;
public deviceStatus: Observable<DeviceStatus>;
constructor() {
this.deviceStatus = new Observable(observer => {
this.deviceStatusObserver = observer;
});
}
getRandom(max): number {
return Math.floor(Math.random() * Math.floor(max));
}
callApi() {
setInterval(() => {
//Mocking data
let status = new DeviceStatus();
status.tempC = this.getRandom(50) + 'C';
status.tempF = this.getRandom(50) + 'F';
status.humidity = this.getRandom(100) + '%';
status.pin1 = true;
status.pin2 = true;
status.pin3 = true;
status.pin4 = true;
this.deviceStatusObserver.next(status);
}, 500);
}
}
还有像这样的组件
import { Component, OnInit } from '@angular/core';
import { Observable } from 'rxjs';
import { GetStatusService } from '../services/get-status.service';
import { DeviceStatus } from '../models/device-status-model'
@Component({
selector: 'app-layout',
templateUrl: './layout.component.html',
styleUrls: ['./layout.component.css']
})
export class LayoutComponent implements OnInit {
dStatus$: Observable<DeviceStatus>;
humidityValue: string; tempValue: string;
constructor(private getStatusService: GetStatusService) {
this.dStatus$ = getStatusService.deviceStatus;
}
ngOnInit() {
this.getStatusService.deviceStatus.subscribe((data) => {
this.tempValue = data.tempC;
this.humidityValue = data.humidity;
});
this.getStatusService.callApi();
}
}
我想将这个 Observable 与异步管道一起使用,所以我删除了
this.getStatusService.deviceStatus.subscribe((data) => {
this.tempValue = data.tempC;
this.humidityValue = data.humidity;
});
然后我开始在控制台上获取 ERROR TypeError: Cannot read property 'next' of undefined
。
即使我使用异步管道,我是否需要订阅 Observable。我查找的所有教程都没有使用订阅者方法。
Link 到 StackBlitz
中的项目
终于想通了,
已更改,在 callApi()
中添加了空检查
callApi() {
setInterval(() => {
let status = new DeviceStatus();
status.tempC = this.getRandom(50) + 'C';
status.tempF = this.getRandom(50) + 'F';
status.humidity = this.getRandom(100) + '%';
status.pin1 = true;
status.pin2 = true;
status.pin3 = true;
status.pin4 = true;
if(!this.deviceStatusObserver)
return;
this.deviceStatusObserver.next(status);
}, 500);
}
我有这样的服务,它模拟了一个 API 调用,
import { Injectable } from '@angular/core';
import { Observable, Subscriber} from 'rxjs';
import { DeviceStatus } from '../models/device-status-model';
@Injectable()
export class GetStatusService {
public deviceStatusObserver: Subscriber<DeviceStatus>;
public deviceStatus: Observable<DeviceStatus>;
constructor() {
this.deviceStatus = new Observable(observer => {
this.deviceStatusObserver = observer;
});
}
getRandom(max): number {
return Math.floor(Math.random() * Math.floor(max));
}
callApi() {
setInterval(() => {
//Mocking data
let status = new DeviceStatus();
status.tempC = this.getRandom(50) + 'C';
status.tempF = this.getRandom(50) + 'F';
status.humidity = this.getRandom(100) + '%';
status.pin1 = true;
status.pin2 = true;
status.pin3 = true;
status.pin4 = true;
this.deviceStatusObserver.next(status);
}, 500);
}
}
还有像这样的组件
import { Component, OnInit } from '@angular/core';
import { Observable } from 'rxjs';
import { GetStatusService } from '../services/get-status.service';
import { DeviceStatus } from '../models/device-status-model'
@Component({
selector: 'app-layout',
templateUrl: './layout.component.html',
styleUrls: ['./layout.component.css']
})
export class LayoutComponent implements OnInit {
dStatus$: Observable<DeviceStatus>;
humidityValue: string; tempValue: string;
constructor(private getStatusService: GetStatusService) {
this.dStatus$ = getStatusService.deviceStatus;
}
ngOnInit() {
this.getStatusService.deviceStatus.subscribe((data) => {
this.tempValue = data.tempC;
this.humidityValue = data.humidity;
});
this.getStatusService.callApi();
}
}
我想将这个 Observable 与异步管道一起使用,所以我删除了
this.getStatusService.deviceStatus.subscribe((data) => {
this.tempValue = data.tempC;
this.humidityValue = data.humidity;
});
然后我开始在控制台上获取 ERROR TypeError: Cannot read property 'next' of undefined
。
即使我使用异步管道,我是否需要订阅 Observable。我查找的所有教程都没有使用订阅者方法。
Link 到 StackBlitz
中的项目终于想通了,
已更改,在 callApi()
callApi() {
setInterval(() => {
let status = new DeviceStatus();
status.tempC = this.getRandom(50) + 'C';
status.tempF = this.getRandom(50) + 'F';
status.humidity = this.getRandom(100) + '%';
status.pin1 = true;
status.pin2 = true;
status.pin3 = true;
status.pin4 = true;
if(!this.deviceStatusObserver)
return;
this.deviceStatusObserver.next(status);
}, 500);
}