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

给定下面的代码:

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

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

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


当前回答

如果你使用React useRef钩子和TypeScript,而不是使用任何你可以做下面的事情。

const ref = useRef<HTMLInputElement>(null);

其他回答

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

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

你可以这样输入:

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

我有同样的错误,把点符号换成了括号符号来抑制它。

例如:

obj.name -> obj['name']

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

selectedActors: any = [];

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

有时,初始值可能为空。 在这种情况下,你可能会说例子

让val = data。notificationId——>这里它会抛出一个错误。 所以我们可以简单地写出来 let val = data && data. notificationid

如果您以这种方式使用UseState,应该不会有问题

const [data, setData] = useState<any>([]);

在Javascript的情况下,它直接工作,因为所有的数据类型都是Any 默认情况下,Typescript中不是这样的,所以你必须让语言知道:)