这类似于#40796374,但这是围绕类型,而我使用接口。

给定下面的代码:

接口Foo { 名称:字符串; } 函数go() { 让实例:Foo | null = null; Let mutator = () => { 实例= { 名称:“字符串” }; }; mutator (); If (instance == null) { console.log('实例为空或未定义'); }其他{ console.log (instance.name); } }

我有一个错误说'属性'名称'不存在类型'从不'。

我不明白实例怎么会是一个“永远”。有人能解释一下吗?


当前回答

在我自己的例子中,当我初始化数组时。我使用:

selectedActors: any = [];

所以一开始它是“动态的”

其他回答

我用下面的表达方式遇到了这个问题:

Const node = item ?<a href={item.link}>{item.name}</a>: item.name

else部分item。name表示属性" name "在类型" never "上不存在。

这是因为如果item对象中什么都没有,那么name属性也不可能存在。

所以当你声明一些基本不可能的事情时,这个警告就会发生(这就是为什么它从来没有)

在我的例子中,发生这种情况是因为我没有输入变量。

所以我创建了搜索界面

export interface Search {
  term: string;
  ...
}

我改变了

searchList = [];

为此,它起作用了

searchList: Search[];

对于typescript开发者… 如果你使用React.useRef()钩子 声明并使用变量类型any,而不是预先分配null。

例子:

const initialRef: any = null;
const ref = React.useRef(initialRef);

在我的情况下(我使用typescript),我试图模拟假数据的响应,其中数据被分配后。我的第一个尝试是:

let response = {status: 200, data: []};

后来,在分配假数据时,它开始抱怨它不能分配给类型'never[]'。 然后我像这样定义响应,它接受了它。

let dataArr: MyClass[] = [];
let response = {status: 200, data: dataArr};

以及假数据的分配:

response.data = fakeData;

在我自己的例子中,当我初始化数组时。我使用:

selectedActors: any = [];

所以一开始它是“动态的”