记录学习过程中写的自定义hooks

  • 防抖
export const useDebounce = <T>(value: T, delay?: number) => {
	const [debounceValue, setDebounceValue] = useState(value);
	useEffect(()=>{
		const debounceTimer = setTimeout(() => setDebounceValue(value), delay);
		return () => clearTimeout(debounceTimer);
	},[]);
	return debounceValue;
}
  • 操作数组
export const useArray = <T>(initArray: T[]) => {
	const [array, setArray] = useState(initArray);
	return {
		array,
		setArray,
		add: (item: T) => setValue([...array, item]),
		removeIndex: (index: number) => {
			const copyArray = [...array];
			copyArray.splice(index, 1);
			setArray(copyArray);
		},
		clear: () => setArray([])
	}
}
  • context 共享全局数据
// 创建context 和 provider
interface Users {
	id: string;
	token: string;
}

const AuthContext = React.createContext<{users: Users} | undefined>(undefined);
AuthContext.displayName = 'AuthContext';

export const AuthProvider = ({children}: {children: ReactNode}) => {
	const users = {id: '', token: ''}
	return <AuthContext.Provider children={children} value={{users}} />
}

// 抽离 useContext,使其可以在AuthProvider定义的范围内使用
export const useAuth = () => {
	const context = useContext(AuthContext);
	if(!context){
		throw new Error('useAuth 必须在 AuthProvider中使用')
	}else{
		return context;
	}
}

// 定义根级AppProvider
export const AppProvider = ({children}: {children: ReactNode}) => {
	return <AuthProvider>
		{ children }
	</AuthProvider>
}

// 最后再把根AppProvider绑定给 App组件
<AppProvider>
	<App />
</AppProvider>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值