首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >角5阵列型铸造

角5阵列型铸造
EN

Stack Overflow用户
提问于 2018-03-25 17:04:09
回答 1查看 409关注 0票数 0

我遇到了以下不寻常的情况:

我有两个模型,为了这个讨论的目的,让他们是CarSpaceship

我编写了一个具有由以下约束定义的输入的组件:这个输入是一个数组,可以是Car或Spaceship,,但不能同时使用。因此,产生以下代码:

代码语言:javascript
复制
@Component({
    selector: 'app-stack-example',
    ...
})
export class StackExample{
    @Input() listOfVehicles: Array<Car> | Array<Spaceship> = [];

...
}

据我理解,这应该是有效的代码,因为我从来不希望它接收一个混合数组。在对设置为这样的输入执行了一些dev之后,我遇到了以下问题:

在以任何方式修改/访问数组时(push()、splice()、indexOf()、find()、findIndex()等),例如:

代码语言:javascript
复制
this.listOfVehicles.push(new Car());

我得到以下错误:

代码语言:javascript
复制
TS2349: Cannot invoke an expression whose type lacks a call signature. Type '((...items: Car[]) => number) | ((...items: Spaceship[]) => number)' has no compatible call signatures.

为什么会发生这种情况?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-03-25 17:08:21

从代码中编译器不清楚数组当前的类型。因此,在对数组使用函数之前,您可能必须检查类型或将数组转换为这两种数组类型之一。

实际上,您的参数不能同时分配给push(item: Car)push(item: Spaceship)这两种可能的类型。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49478466

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档