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

给定下面的代码:

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

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

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


当前回答

如果你把Component写成React。FC,使用useState(),

这样写会很有帮助:

const [arr, setArr] = useState<any[]>([])

其他回答

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

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

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

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

以及假数据的分配:

response.data = fakeData;

如果你把Component写成React。FC,使用useState(),

这样写会很有帮助:

const [arr, setArr] = useState<any[]>([])

在useState中,如果你从未声明过类型:

它假设它的类型是never,所以它显示这个错误:"属性不存在类型'never'"

你可以这样输入:

const [datalist, setDataList] = useState<Array<Object>>([]);

在你的组件中。Ts文件只是像下面那样声明数组

public arrayName = ([] as any[]);

它和我一起为Angular工作过

这似乎类似于这个问题:当使用strictNullChecks在回调中更改值时,False“属性不存在于类型'never'”,这是这个问题(讨论)的副本:控制流分析中的权衡。

这个讨论很长,如果你找不到好的解决方案,你可以试试这个:

if (instance == null) {
    console.log('Instance is null or undefined');
} else {
    console.log(instance!.name); // ok now
}