Typescript属性concat不存在

时间:2017-08-21 16:47:47

标签: javascript angular typescript

我的代码按预期工作,但是Typescript显然有一些我已经完成的问题,我想了解它是什么。 Typescrpt报告以下错误:

enter image description here

以下是工作代码。

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'] });
})

enter image description here

感谢您的任何意见。

0 个答案:

没有答案