本文整理匯總了TypeScript中react.useCallback函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript useCallback函數的具體用法?TypeScript useCallback怎麽用?TypeScript useCallback使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了useCallback函數的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: default
export default () => {
const handleContextMenu = React.useCallback((evt: MouseEvent) => {
// allow native context menu if it is an input element
if (evt.target instanceof HTMLInputElement) {
return
}
// disable native context menu
evt.preventDefault()
}, [])
useEventListener(document, 'contextmenu', handleContextMenu)
const handleKeyDown = React.useCallback((evt: KeyboardEvent) => {
const isFocusedOnInputWithoutValue =
document.activeElement instanceof HTMLInputElement && document.activeElement.value === ''
if (evt.key === 'Escape' && isFocusedOnInputWithoutValue) {
window.close()
}
}, [])
useEventListener(document, 'keydown', handleKeyDown)
const handleMouseDown = React.useCallback((evt: MouseEvent) => {
// disable the scrolling arrows after middle click
if (evt.button === 1) evt.preventDefault()
}, [])
useEventListener(document, 'mousedown', handleMouseDown)
}
示例2: catch
export function useSessionStorage<T>(key: string, initialValue: T) {
const [keyValue, setKeyValue] = useState<T>(() => {
try {
let value = window.sessionStorage.getItem(key);
return value !== null ? JSON.parse(value) : initialValue;
} catch (error) {
// Return default value if JSON parsing fails
return initialValue;
}
});
// Wrap in useCallback so the wrapped function is reused
const setValue = useCallback(
(value: T) => {
try {
window.sessionStorage.setItem(key, JSON.stringify(value));
} catch (e) {
// TODO: What should we do here?
// Example: quota limit reached
}
setKeyValue(value);
},
[setKeyValue]
);
return [keyValue, setValue];
}
示例3: useState
function useAsync<Result>(fn: () => Promise<Result>) {
const [isLoading, setIsLoading] = useState(false);
const [result, setResult] = useState<Result | null>(null);
const [err, setError] = useState(null);
const isMounted = useIsMounted();
const run = useCallback(async () => {
setIsLoading(true);
try {
const res = await fn();
if (isMounted.current) {
setResult(res);
}
} catch (error) {
if (isMounted.current) {
setError(error);
}
} finally {
if (isMounted.current) {
setIsLoading(false);
}
}
}, [fn]);
return {
isLoading,
result,
error: err,
run,
};
}
示例4: useComponentSize
export function useComponentSize(ref: React.RefObject<HTMLElement>) {
let [componentSize, setComponentSize] = useState(getSize(ref.current));
const handleResize = useCallback(
function handleResize() {
if (ref.current) {
setComponentSize(getSize(ref.current));
}
},
[ref]
);
useLayoutEffect(() => {
if (!ref.current) {
return;
}
if (SUPPORTS_RESIZE_OBSERVER) {
let resizeObserver = new ResizeObserver(() => handleResize());
resizeObserver.observe(ref.current);
return () => {
resizeObserver.disconnect();
};
} else {
window.addEventListener('resize', handleResize);
return () => {
window.removeEventListener('resize', handleResize);
};
}
}, [handleResize, ref]);
return componentSize;
}
示例5: async
export default function useResource<T>(
defaultData: T,
pendingByDefault: boolean = false
): [Resource<T>, ((promise: Promise<T>) => any), (pending?: boolean) => void] {
const [state, setState] = React.useState<Resource<T>>({
data: defaultData,
error: null,
fulfilled: false,
pending: pendingByDefault
});
const setData = React.useCallback(
async (promise: Promise<T>) => {
setState({
...state,
error: null,
fulfilled: false,
pending: true
});
try {
setState({
...state,
data: await promise,
fulfilled: true,
pending: false
});
} catch (e) {
setState({
...state,
data: defaultData,
error: e.message,
pending: false
});
}
},
[state]
);
const markPending = React.useCallback(
(pending = true) => {
setState({ ...state, pending });
},
[state]
);
return [state, setData, markPending];
}
示例6: useHistory
export const useUrlState = <State>({
defaultState,
decodeUrlState,
encodeUrlState,
urlStateKey,
}: {
defaultState: State;
decodeUrlState: (value: RisonValue | undefined) => State | undefined;
encodeUrlState: (value: State) => RisonValue | undefined;
urlStateKey: string;
}) => {
const history = useHistory();
const urlStateString = useMemo(
() => {
if (!history) {
return;
}
return getParamFromQueryString(getQueryStringFromLocation(history.location), urlStateKey);
},
[history && history.location, urlStateKey]
);
const decodedState = useMemo(() => decodeUrlState(decodeRisonUrlState(urlStateString)), [
decodeUrlState,
urlStateString,
]);
const state = useMemo(() => (typeof decodedState !== 'undefined' ? decodedState : defaultState), [
defaultState,
decodedState,
]);
const setState = useCallback(
(newState: State | undefined) => {
if (!history) {
return;
}
const location = history.location;
const newLocation = replaceQueryStringInLocation(
location,
replaceStateKeyInQueryString(
urlStateKey,
typeof newState !== 'undefined' ? encodeUrlState(newState) : undefined
)(getQueryStringFromLocation(location))
);
if (newLocation !== location) {
history.replace(newLocation);
}
},
[encodeUrlState, history, history && history.location, urlStateKey]
);
return [state, setState] as [typeof state, typeof setState];
};
示例7: clearInterval
const useDragAndDropContainerEvents = ({margin = 20}: {margin?: number} = {}) => {
const {activeKey} = React.useContext(DragAndDropContext)
const isDragging = activeKey !== null
const scrollingTimeoutRef = React.useRef<NodeJS.Timeout>()
const clearScroll = React.useCallback(() => {
if (scrollingTimeoutRef.current !== undefined) {
clearInterval(scrollingTimeoutRef.current)
scrollingTimeoutRef.current = undefined
}
}, [])
React.useEffect(() => {
if (!isDragging) {
clearScroll()
}
}, [clearScroll, isDragging])
return React.useMemo(() => {
const scroll = (containerElement: HTMLElement, {isUpward}: {isUpward: boolean}) => {
clearScroll()
scrollingTimeoutRef.current = setInterval(() => {
containerElement.scrollTo({
top: containerElement.scrollTop + (isUpward ? -1 : 1) * 20
})
}, 50)
}
const onMouseMove = (evt: MouseEvent | React.MouseEvent) => {
if (!isDragging) return
if (evt.currentTarget instanceof HTMLElement) {
const rect = evt.currentTarget.getBoundingClientRect()
const displacementTop = Math.abs(rect.top - evt.clientY)
const displacementBottom = Math.abs(rect.bottom - evt.clientY)
if (displacementTop <= margin) {
scroll(evt.currentTarget, {
isUpward: true
})
} else if (displacementBottom <= margin) {
scroll(evt.currentTarget, {
isUpward: false
})
} else {
clearScroll()
}
}
}
return {
onMouseMove
}
}, [clearScroll, isDragging, margin])
}
示例8: setBodySizeStack
const useBodySizeStack = (): {
globalBodySize?: BodySize
appendBodySize: (state: BodySize) => void
removeBodySize: (state: BodySize) => void
} => {
const {bodySizeStack, setBodySizeStack} = React.useContext(AbsolutePositionContext)
const globalBodySize = React.useMemo(() => {
return bodySizeStack.reduce(
(acc, bodySize) => {
return {
height: bodySize.height ? Math.max(bodySize.height, acc.height || 0) : acc.height,
width: bodySize.width ? Math.max(bodySize.width, acc.width || 0) : acc.width
}
},
{
height: undefined,
width: undefined
}
)
}, [bodySizeStack])
const appendBodySize = React.useCallback(
(newBodySize: BodySize) => {
setBodySizeStack((prevBodySize) => [...prevBodySize, newBodySize])
},
[setBodySizeStack]
)
const removeBodySize = React.useCallback(
(oldBodySize: BodySize) => {
setBodySizeStack((prevBodySize) => {
return prevBodySize.filter((state) => state !== oldBodySize)
})
},
[setBodySizeStack]
)
return {
globalBodySize,
appendBodySize,
removeBodySize
}
}
示例9: dispatch
const useMapDispatchToCallback = <T, U extends Array<V>, V>(
dispatch: React.Dispatch<T>,
creator: (...args: U) => T
) => {
return React.useCallback(
(...args: U) => {
dispatch(creator(...args))
},
[creator, dispatch]
)
}
示例10: useHashScrolling
export function useHashScrolling() {
const offset = useScrollOffset();
const calcedOffset = offset.getCalcedHashOffset();
const callback = useCallback(() => {
return initHashScrolling(calcedOffset, () => offset.temporarilyDisabledWatching(500));
}, [calcedOffset]);
useEffect(() => {
callback();
}, [callback]);
}