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