const [state, dispatch] = useState(initData)
const [count, setCount] = useState('河畔一角');
// 更新count
setCount('zhangsan')
const [user, setUser] = useState({ name: '河畔一角', age: 30 });
// 更新对象
setUser({...user, age:20})
const [list, setList] = useState(['Tom', 'Jack']);
// 更新数组
setList([...list, 'zhangsan'])
const [count, setCount] = useState(0);
// 点击按钮,执行三次// 1
setCount(count + 1)
setCount(count + 1)
setCount(count + 1)
// 点击按钮,异步执行
setTimeout(()=>{
setCount(count + 1)
})
const [count, setCount] = useState(0);
// 使用函数更新
setCount(count => count + 1)
https://zh-hans.reactjs.org/docs/hooks-rules.html
不要在循环,条件或嵌套函数中调用 Hook, 确保总是在你的 React 函数的最顶层以及任何 return 之前调用他们。遵守这条规则,你就能确保 Hook 在每一次渲染中都按照同样的顺序被调用。这让 React 能够在多次的 useState
和 useEffect
调用之间保持 hook 状态的正确。(如果你对此感到好奇,我们在下面会有更深入的解释。)
不要在普通的 JavaScript 函数中调用 Hook
遵循此规则,确保组件的状态逻辑在代码中清晰可见。