使用useEffect,如何跳过对初始渲染的效果?

使用useEffect,如何跳过对初始渲染的效果?,第1张

使用useEffect,如何跳过对初始渲染效果

如指南所述,

效果挂钩(useEffect)增加了从功能组件执行副作用的功能。它的作用与React类中的componentDidMount,componentDidUpdate和componentWillUnmount相同,但统一为一个API。

在指南中的此示例中,预期

count
仅在初始渲染时为0:

const [count, setCount] = useState(0);

因此,它将

componentDidUpdate
与其他检查一起使用:

useEffect(() => {  if (count)    document.title = `You clicked ${count} times`;}, [count]);

基本上,这是可以使用而不是可以使用的自定义挂钩的

useEffect
工作方式:

function useDidUpdateEffect(fn, inputs) {  const didMountRef = useRef(false);  useEffect(() => {    if (didMountRef.current)      fn();    else      didMountRef.current = true;  }, inputs);}

致谢@Tholle

useRef
而不是进行建议
setState



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/4887349.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-11
下一篇 2022-11-11

发表评论

登录后才能评论

评论列表(0条)

保存