标签:count const 自定义 hooks useSyncCallback proxyState current useState
自定义hooks实现在useState改变值之后立刻获取到最新的值
import React from 'react'
function App () {
let [count, setCount] = React.useState(0)
const add = () => {
setCount(count + 1)
console.log(count)
}
return (
<div>
<h1>{count}</h1>
<button onClick={add}>点我加 1 </button>
</div>
)
}
export default App;
以上代码每次点击按钮得到的 count 值都是上一次的值
再来看看以下代码
import React from 'react'
import useSyncCallback from './hooks/hook'
function App () {
let [count, setCount] = React.useState(0)
const add = () => {
setCount(count + 1)
fnc()
}
const fnc = useSyncCallback(() => {
console.log(count)
})
return (
<div>
<h1>{count}</h1>
<button onClick={add}>点我加 1 </button>
</div>
)
}
export default App;
以上代码可以得到更新之后的值
下面写上 useSyncCallback 函数的实现
import { useEffect, useState, useCallback } from "react";
const useSyncCallback = (callback) => {
const [proxyState, setProxyState] = useState({ current: false });
const Func = useCallback(() => {
setProxyState({ current: true });
}, [proxyState]);
useEffect(() => {
if (proxyState.current === true) setProxyState({ current: false });
}, [proxyState]);
useEffect(() => {
proxyState.current && callback();
});
return Func;
};
export default useSyncCallback;
标签:count,const,自定义,hooks,useSyncCallback,proxyState,current,useState 来源: https://www.cnblogs.com/liujis/p/16053144.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。