ahooks是一款由阿里巴巴开发团队设计的React Hooks库,提供了一系列实用的React Hooks,以便开发者更好地使用React的功能。ahooks的设计原则是“最小API,最大自由”,旨在提供最小的、最易于理解和使用的API,同时保留最大的使用自由度。
使用npm或yarn安装ahooks:
npm install ahooks
# 或者
yarn add ahooks
API介绍合集:
- ahooks.js:一款强大的React Hooks库及其API使用教程(一)
- ahooks.js:一款强大的React Hooks库及其API使用教程(二)
useAsyncEffect
是一个用于处理异步操作的 Hook,它可以在 effect 中使用 async/await。
import { useAsyncEffect } from 'ahooks';
function App() {
useAsyncEffect(async () => {
const data = await fetchData();
console.log(data);
}, []);
return <div>...</div>;
}
上述代码中,useAsyncEffect
接收一个异步函数和依赖数组作为参数。异步函数会在组件挂载后和依赖项改变后执行。
useDebounceEffect
是一个在依赖项改变后延迟执行副作用的 Hook。
import { useDebounceEffect } from 'ahooks';
function App() {
const [value, setValue] = useState('');
useDebounceEffect(() => {
console.log(value);
}, [value], 500);
return <input value={value} onChange={e => setValue(e.target.value)} />;
}
上述代码中,useDebounceEffect
接收一个函数,依赖数组和延迟时间作为参数。函数会在依赖项改变后的指定延迟时间后执行。
useDebounceFn
是一个用于延迟函数执行的 Hook。
import { useDebounceFn } from 'ahooks';
function App() {
const { run } = useDebounceFn(() => {
console.log('Hello');
}, 500);
return <button onClick={run}>Say Hello</button>;
}
上述代码中,useDebounceFn
接收一个函数和延迟时间作为参数,返回一个对象,该对象包含一个run
方法,当调用这个方法时,会在指定延迟时间后执行传入的函数。
useThrottleFn
是一个用于节流函数执行的 Hook。
import { useThrottleFn } from 'ahooks';
function App() {
const { run } = useThrottleFn(() => {
console.log('Hello');
}, 500);
return <button onClick={run}>Say Hello</button>;
}
上述代码中,useThrottleFn
接收一个函数和延迟时间作为参数,返回一个对象,该对象包含一个run
方法,当调用这个方法时,会以节流的方式执行传入的函数。
useThrottleEffect
是一个在依赖项改变后以节流方式执行副作用的 Hook。
import { useThrottleEffect } from 'ahooks';
function App() {
const [value, setValue] = useState('');
useThrottleEffect(() => {
console.log(value);
}, [value], 500);
return <input value={value} onChange={e => setValue(e.target.value)} />;
}
上述代码中,useThrottleEffect
接收一个函数,依赖数组和延迟时间作为参数。函数会在依赖项改变后以节流的方式执行。
useDeepCompareEffect
是一个用于深度比较依赖项的 Hook,只有当依赖项深度比较改变时,才会执行副作用。
import { useDeepCompareEffect } from 'ahooks';
function App() {
const [value, setValue] = useState({ key: 'value' });
useDeepCompareEffect(() => {
console.log(value);
}, [value]);
return <div>...</div>;
}
上述代码中,useDeepCompareEffect
接收一个函数和依赖数组作为参数。函数只有在依赖项深度比较改变时才会执行。
usePrevious
是一个用于获取上一个状态或属性的 Hook。
import { usePrevious } from 'ahooks';
function App() {
const [count, setCount] = useState(0);
const prevCount = usePrevious(count);
return (
<div>
<p>Now: {count}, before: {prevCount}</p>
<button onClick={() => setCount(count + 1)}>Increment</button>
</div>
);
}
上述代码中,usePrevious
接收当前状态或属性作为参数,返回该状态或属性的上一个值。
useRafState
是一个用于在下一个动画帧中更新状态的 Hook。
import { useRafState } from 'ahooks';
function App() {
const [count, setCount] = useRafState(0);
return (
<div>
<p>{count}</p>
<button onClick={() => setCount(count + 1)}>Increment</button>
</div>
);
}
上述代码中,useRafState
接收初始状态作为参数,返回当前状态和一个设置函数。设置函数会在下一个动画帧中更新状态。
useSafeState
是一个安全的状态 Hook,它可以确保在组件卸载后不会设置状态。
import { useSafeState } from 'ahooks';
function App() {
const [count, setCount] = useSafeState(0);
return (
<div>
<p>{count}</p>
<button onClick={() => setCount(count + 1)}>Increment</button>
</div>
);
}
上述代码中,useSafeState
接收初始状态作为参数,返回当前状态和一个设置函数。设置函数会确保在组件卸载后不会设置状态。
useGetState
是一个用于获取当前状态的 Hook,无论何时调用,都会返回最新的状态。
import { useGetState } from 'ahooks';
function App() {
const [count, setCount, getState] = useGetState(0);
const handleDouble = () => {
setCount(getState() * 2);
};
return (
<div>
<p>{count}</p>
<button onClick={handleDouble}>Double</button>
</div>
);
}
上述代码中,useGetState
接收初始状态作为参数,返回当前状态,一个设置函数,和一个获取当前状态的函数。无论何时调用获取状态的函数,都会返回最新的状态。
更多关于ahooks.js的API介绍,请查看专栏:ahooks.js:一款强大的React Hooks库