一一七、react Hooks实现forceUpdate

须旭
2023-12-01

如果你的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的效果。

 类似资料: