一一七、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
推荐阅读
-
一一七、react Hooks实现forceUpdate
-
基于 React hooks + Typescript + Cesium 实现要素绘制
-
基于 React hooks + Typescript + Cesium 通过 dom 实现扩散点绘制并封装组件
-
React Hooks 实现和由来以及解决的问题详解
-
React 实现table内单元格可编辑 (hooks)
-
一一七、react Hooks实现forceUpdate
-
React Hooks 实现和由来以及解决的问题详解
-
基于 React hooks + Typescript + Cesium 实现要素绘制
-
基于 React hooks + Typescript + Cesium 通过 dom 实现扩散点绘制并封装组件