响应docs状态:不调用循环、条件或嵌套函数中的钩子。
调用钩子是否意味着只调用useState,例如const [state, useState] = useState(0)
在条件词中打电话给赛特怎么样?
这是代码破坏了钩子的规则吗?
const [oneHook, setOneHook] = useState(0)
const [anotherHook, setAnotherHook] = useState(false)
if (something) {
setOneHook(1)
setAnotherHook(true)
} else {
setOneHook(0);
setAnotherHook(false)
}谢谢!
发布于 2019-11-01 04:11:32
不,那个代码示例没有破坏钩子的规则。每次组件呈现时,对useState的调用都会以完全相同的顺序进行,这样就可以了。
我想指出的是,在组件的主体中立即设置状态没有多大意义。当组件挂载时,它将使用状态的初始值开始呈现,但在完成呈现之前,状态已经更改,必须重新启动。但据推测,这只是示例中的一个工件,在您的实际代码中,if将位于useEffect或其他一些实用代码位置内。
https://stackoverflow.com/questions/58653983
复制相似问题