欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

一一七、react Hooks实现forceUpdate

程序员文章站 2022-07-03 09:24:56
如果你的render()方法依赖于一些其他的数据,你可以告诉React组件需要通过调用forceUpdate()重新渲染。调用forceUpdate()会导致组件跳过shouldComponentUpdate(),直接调用render()。这将触发组件的正常生命周期方法,包括每个子组件的shouldComponentUpdate()方法。forceUpdate就是重新render。有些变量不在state上,当时你又想达到这个变量更新的时候,刷新render;或者state里的某个变量层次太深,更新的时....

如果你的render()方法依赖于一些其他的数据,你可以告诉React组件需要通过调用forceUpdate()重新渲染。
调用forceUpdate()会导致组件跳过shouldComponentUpdate(),直接调用render()。这将触发组件的正常生命周期方法,包括每个子组件的shouldComponentUpdate()方法。
forceUpdate就是重新render。有些变量不在state上,当时你又想达到这个变量更新的时候,刷新render;或者state里的某个变量层次太深,更新的时候没有自动触发render。这些时候都可以手动调用forceUpdate自动触发render

useReducer

基础hook useState和useReducer提供了可以刷新(更新)函数组件的途径。同样,也是自定义hook刷新的途径。如果想让自定义hook去刷新函数组件,那只能在自定义组件中使用useState或者useReducer来强制刷新,达到类似以前forUpdate的效果。

function useForceUpdate() {
  const [ , forceUpdateDispatch ] = useReducer(v => v + 1, 0)
  useEffect(() => {
    const unSubscribeFn = store.subscribe(() => {
      forceUpdateDispatch();
    })
    return unSubscribeFn;
  }, [ store ])
  return store;
}

当数据发生改变时候,会调用forceUpdateDispatch ,改变flag,从而导致这个reducer变化,触发自定义hook useRedux变化,连锁触发App刷新,达到以前forceUpdate的效果。

本文地址:https://blog.csdn.net/zm06201118/article/details/107620899