当前位置: 移动技术网 > IT编程>开发语言>.net > 一一七、react Hooks实现forceUpdate

一一七、react Hooks实现forceUpdate

2020年07月29日  | 移动技术网IT编程  | 我要评论
如果你的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

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网