繁体   English   中英

如何使自定义钩子返回一个函数,该函数使用另一个钩子

[英]How to make Custom Hook returns a function, which uses another hook

所以我有一个自定义钩子,我想在另一个组件的多个地方使用它,比如一个函数,它接受参数 (Ei For useNavigate() from react-router-dom-v6 ,我们将它用作const navigate = useNavigate()然后navigate('./url/to/navigate')可以在多个地方使用)。

但是在自定义挂钩中,我想通过另一个自定义挂钩处理该参数值。 这是我尝试过的,但 React 不允许我在函数内部有这样的钩子:

//useCustomHook.js
function usePrevious(value) {
    const ref = useRef();
    useEffect(() => {
        ref.current = value;
    });
    return ref.current;
}
...
export default function useCustomHook() {
    function processingData(currentState){
        const previousState = usePrevious(currentState);    //React does not allow to have hook here
        return process(currentState, previousState);
    }
    return processingData;
}

//Component.js
...
const cusHook = useCustomHook();
...
useEffect(()=>{
   cusHook(state1)
},[])

useEffect(()=>{
   cusHook(state2)
},[temp])

有没有办法可以做到这一点?

不,您无法在纯 JavaScript 函数中使用钩子。 为什么不做这样的事情:

   export default function useCustomHook(currentState) {
        const previousState = usePrevious(currentState);
        const processingData = () => {
               return process(currentState, previousState);
        }
       return processingData;
   }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM