我的代码按预期工作,但是Typescript显然有一些我已经完成的问题,我想了解它是什么。 Typescrpt报告以下错误:
以下是工作代码。
UserWarning
我在map方法中添加if条件后出现错误。在添加这些条件之前,我的代码如下:
getZones() {
this.spinner.show();
this.zonesService.getZonesByUserId(this.userId)
.mergeMap(zones => Observable.from(zones))
.mergeMap(zone => this.zonesService.getAssociations(zone['id'], '/team')
.catch(() => Observable.of(null))
.map(team => {
if (team['team']) {
return Object.assign({}, zone, { teamName: team['team']['name'] });
} else {
return zone;
}
})
)
.mergeMap(zone => this.zonesService.getAssociations(zone['id'], '/site')
.catch(() => Observable.of(null))
.map(site => {
if (site['site']) {
return Object.assign({}, zone, { siteName: site['site']['name'] });
} else {
return zone;
}
})
)
.reduce((zones, zone) => {
return zones.concat(zone);
}, [])
.subscribe(
_data => {
this.zones = _data
.map(zone => {
if (zone['personal']) {
this.personalZone = zone;
this.personalZone['name'] = 'My Personal Zone';
this.personalZone['teamName'] = '';
}
return zone;
})
.filter(zone => {
return zone['personal'] !== true;
})
.map(zone => {
if (zone['siteName'] === undefined) {
zone['siteName'] = 'NO_SITE_NAME';
}
return zone;
});
if (this.zones && this.personalZone !== null) {
this.zones.unshift(this.personalZone);
}
this.loading = false;
this.spinner.hide();
},
_error => {}
);
};
需要条件来处理服务器无法返回请求对象的实例。现在,Typescript似乎有代码问题。确保reduce函数中的zones参数是一个数组,并确保_data值也是一个数组。出于某种原因,Typescript认为这些是对象。
控制台输出:
.map(team => {
return Object.assign({}, zone, { teamName: team['team']['name'] });
})
.map(site => {
return Object.assign({}, zone, { siteName: site['site']['name'] });
})
感谢您的任何意见。