Category | Sensors |
---|---|
Export Size | 790 B |
Last Changed | 2 days ago |
Reactive mouse position
import { useMouse } from '@vueuse/core' const { x, y, sourceType } = useMouse()
Touch is enabled by default. To only detect mouse changes, set touch
to false
. The dragover
event is used to track mouse position while dragging.
const { x, y } = useMouse({ touch: false })
It's also possible to provide a custom extractor function to get the position from the event.
import { type UseMouseEventExtractor, useMouse, useParentElement } from '@vueuse/core' const parentEl = useParentElement() const extractor: UseMouseEventExtractor = event => ( event instanceof Touch ? null : [event.offsetX, event.offsetY] ) const { x, y, sourceType } = useMouse({ target: parentEl, type: extractor })
Touch is enabled by default. To only detect mouse changes, set touch
to false
. The dragover
event is used to track mouse position while dragging.
const { x, y } = useMouse({ touch: false })
This function also provides a renderless component version via the
@vueuse/components
package. Learn more about the usage.
<UseMouse v-slot="{ x, y }"> x: {{ x }} y: {{ y }} </UseMouse>
export type UseMouseCoordType = "page" | "client" | "screen" | "movement" export type UseMouseSourceType = "mouse" | "touch" | null export type UseMouseEventExtractor = ( event: MouseEvent | Touch ) => [x: number, y: number] | null | undefined export interface UseMouseOptions extends ConfigurableWindow, ConfigurableEventFilter { /** * Mouse position based by page, client, screen, or relative to previous position * * @default 'page' */ type?: UseMouseCoordType | UseMouseEventExtractor /** * Listen events on `target` element * * @default 'Window' */ target?: MaybeRefOrGetter<Window | EventTarget | null | undefined> /** * Listen to `touchmove` events * * @default true */ touch?: boolean /** * Reset to initial value when `touchend` event fired * * @default false */ resetOnTouchEnds?: boolean /** * Initial values */ initialValue?: Position } /** * Reactive mouse position. * * @see https://vueuse.org/useMouse * @param options */ export declare function useMouse(options?: UseMouseOptions): { x: Ref<number> y: Ref<number> sourceType: Ref<UseMouseSourceType> } export type UseMouseReturn = ReturnType<typeof useMouse>
© 2019-present Anthony Fu
Licensed under the MIT License.
https://vueuse.org/core/useMouse/