fastlion-amis
Version:
一种MIS页面生成工具
20 lines (15 loc) • 525 B
text/typescript
import {useCallback, useState} from 'react';
import isFunction from 'lodash/isFunction';
const useSetState = <T extends object>(
initialState: T = {} as T
): [T, (patch: Partial<T> | ((prevState: T) => Partial<T>)) => void] => {
const [state, setState] = useState<T>(initialState);
const setMergeState = useCallback(patch => {
setState(prevState => ({
...prevState,
...(isFunction(patch) ? patch(prevState) : patch)
}));
}, []);
return [state, setMergeState];
};
export default useSetState;