本文整理匯總了TypeScript中react.useRef函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript useRef函數的具體用法?TypeScript useRef怎麽用?TypeScript useRef使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了useRef函數的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: addEventListener
const useKeyBindingsEvent = (
{key, priority, windowId}: KeyBindingMeta,
callback?: (evt: KeyboardEvent) => void
) => {
const {addEventListener, removeEventListener} = React.useContext(KeyBindingsContext)
const callbackRef = React.useRef(callback)
callbackRef.current = callback
// use ref as `key` may be a RegExp instance and passing new reference every time
// it made a trade-off, updating key now doesn't rerun addEventListener/removeEventListener
const keyRef = React.useRef(key)
keyRef.current = key
React.useEffect(() => {
const meta = {key: keyRef.current, priority, windowId}
const wrappedCallback = (evt: KeyboardEvent) => {
if (callbackRef.current) {
callbackRef.current(evt)
}
}
addEventListener(meta, wrappedCallback)
return () => {
removeEventListener(meta, wrappedCallback)
}
}, [addEventListener, priority, removeEventListener, windowId])
}
示例2: useEffect
export function usePrevious<T>(value: T) {
const ref: React.MutableRefObject<T | null> = useRef<T>(null);
useEffect(() => {
ref.current = value;
});
return ref.current;
}
示例3: useReadClassState
export function useReadClassState(
fixture: React.ReactNode,
decoratorId: FixtureDecoratorId,
elRefs: React.MutableRefObject<ElRefs>
) {
const elPaths = findRelevantElementPaths(fixture);
const { fixtureState, setFixtureState } = React.useContext(FixtureContext);
const timeoutId = React.useRef<null | number>(null);
React.useEffect(() => {
// The check should run even if no element paths are found at mount, because
// the fixture can change during the lifecycle of a FixtureCapture instance
// and the updated fixture might contain elements of stateful components
scheduleStateCheck();
return () => {
if (timeoutId.current) {
clearTimeout(timeoutId.current);
}
};
});
function scheduleStateCheck() {
// Is there a better way to listen to component state changes?
timeoutId.current = window.setTimeout(checkState, REFRESH_INTERVAL);
}
function checkState() {
let fixtureStateChangeScheduled = false;
Object.keys(elRefs.current).map(async elPath => {
if (elPaths.indexOf(elPath) === -1) {
throw new Error(
`[FixtureCapture] Child ref exists for missing element path "${elPath}"`
);
}
const { state } = elRefs.current[elPath];
const elementId = { decoratorId, elPath };
const fsClassState = findFixtureStateClassState(fixtureState, elementId);
if (
fsClassState &&
state &&
!doesFixtureStateMatchClassState(fsClassState, state)
) {
fixtureStateChangeScheduled = true;
setFixtureState(prevFs => ({
...prevFs,
classState: updateFixtureStateClassState({
fixtureState: prevFs,
elementId,
values: createValues(state)
})
}));
}
});
if (!fixtureStateChangeScheduled) {
scheduleStateCheck();
}
}
}
示例4: useRef
export function useRefObject<T>(input: T): RefObject<T> {
const ref = useRef(input)
useEffect(() => {
ref.current = input
}, [input])
return ref
}
示例5: useState
export const useQuery = (value: string): Output => {
const [result, setResult] = useState<Result>([]);
const [loading, setLoading] = useState(false);
const [loaded, setLoaded] = useState(false);
const debounce = useRef<any>(null);
useEffect(() => {
worker.load().then(() => {
setLoaded(true);
});
}, []);
useEffect(
() => {
if (!value) return;
if (debounce.current) {
clearTimeout(debounce.current);
}
setLoading(true);
debounce.current = setTimeout(() => {
worker.solve(value).then((data: any) => {
setResult(data);
setLoading(false);
});
}, 140);
},
[value],
);
return { loaded, loading, data: result };
};
示例6: Portal
function Portal ({ target, children }: Props) {
const domStore = useRef<Element>(null)
if (!domStore.current) {
domStore.current = document.getElementById(target)
}
return createPortal(children, domStore.current)
}
示例7: useFixtureStateRef
// Make latest fixture state accessible in ref callback
function useFixtureStateRef(fixtureState: FixtureState) {
const ref = React.useRef(fixtureState);
React.useEffect(() => {
ref.current = fixtureState;
});
return ref;
}
示例8: useRef
export function useDrop<
DragObject extends DragObjectWithType,
DropResult,
CollectedProps
>(
spec: DropTargetHookSpec<DragObject, DropResult, CollectedProps>,
): [CollectedProps, ConnectDropTarget] {
const specRef = useRef(spec)
invariant(spec.accept != null, 'accept must be defined')
const [monitor, connector] = useDropTargetMonitor()
useDropHandler(specRef, monitor, connector)
const result: CollectedProps = useMonitorOutput(
monitor,
specRef.current.collect || (() => ({} as CollectedProps)),
() => connector.reconnect(),
)
const connectDropTarget = useMemo(() => connector.hooks.dropTarget(), [
connector,
])
useEffect(() => {
connector.dropTargetOptions = spec.options || null
connector.reconnect()
}, [spec.options])
return [result, connectDropTarget]
}
示例9: useMemo
export const useSubscription = <T, TVariables = OperationVariables>(
query: DocumentNode,
options: SubscriptionOptions<T, TVariables> = {},
): {
data: T | { [key: string]: void }
error?: GraphQLError
loading: boolean
} => {
const onSubscriptionData = options.onSubscriptionData
const prevOptions = useRef<typeof options | null>(null)
const client = useApolloClient()
const [data, setData] = useState<T | {}>({})
const [error, setError] = useState<GraphQLError | null>(null)
const [loading, setLoading] = useState<boolean>(true)
const subscriptionOptions = {
query,
variables: options.variables,
fetchPolicy: options.fetchPolicy,
}
useEffect(
() => {
prevOptions.current = subscriptionOptions
const subscription = client
.subscribe<{ data: T }, TVariables>(subscriptionOptions)
.subscribe({
next: ({ data }) => {
setData(data)
if (onSubscriptionData) {
onSubscriptionData({ client, subscriptionData: data })
}
},
error: err => {
setError(err)
setLoading(false)
},
complete: () => {
setLoading(false)
},
})
return () => {
subscription.unsubscribe()
}
},
[isEqual(prevOptions.current, subscriptionOptions) ? prevOptions.current : subscriptionOptions],
)
return useMemo(
() => ({
data,
error,
loading,
}),
[data, error, loading],
)
}
示例10: 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])
}