nek*_*zer 0 types typescript reactjs use-state
如何在 UseState 数组中定义嵌套数组的类型
定义的接口 -
interface ToyProps {
car: string | null;
doll: number | null;
}
interface SettingsProps {
[key: string]: ToyProps[];
}
Run Code Online (Sandbox Code Playgroud)
状态 -
const [state, setstate]:SettingsProps = React.useState({
toys: [
{
cars: "car 1",
doll: "doll 1",
},
{
cars: "car 2",
doll: "doll 3",
},
],
});
Run Code Online (Sandbox Code Playgroud)
我按照上面的方式定义了,但仍然出现类型错误
您正在将该类型应用于数组,该数组包含状态对象和状态设置器函数。
\n相反,将其作为类型参数提供给useState:
const [state, setstate] = React.useState<SettingsProps>({\n// \xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92\xe2\x88\x92^^^^^^^^^^^^^^^\n // ...\n});\nRun Code Online (Sandbox Code Playgroud)\ntype 参数驱动 的返回类型,这将适当地设置和useState的类型。statesetstate