Skip to content

useKeyModifier

类别
导出体积
644 B
上次更改
5 minutes ago

响应式地跟踪修饰键状态。跟踪任何支持的修饰键的状态 - 请参阅浏览器兼容性说明。

通过 Vue School 的这个免费视频课程来学习 useKeyModifier!

示例

大写锁定
数字锁定
滚动锁定
Shift
Ctrl
Alt

使用方法

ts
import { useKeyModifier } from '@vueuse/core'

const capsLockState = useKeyModifier('CapsLock')

console.log(capsLockState.value)

事件

你可以自定义哪些事件将触发状态更新。默认情况下,这些事件是 mouseupmousedownkeyupkeydown。要自定义这些事件:

ts
import { useKeyModifier } from '@vueuse/core'

const capsLockState = useKeyModifier('CapsLock', { events: ['mouseup', 'mousedown'] })

console.log(capsLockState) // null

// 通过按键开启大写锁定
console.log(capsLockState) // null

// 鼠标按钮被点击
console.log(capsLockState) // true

初始状态

默认情况下,返回的 ref 将是 Ref<boolean | null>,直到收到第一个事件为止。你可以通过以下方式明确地将初始状态传递给它:

ts
const capsLockState1 = useKeyModifier('CapsLock') // Ref<boolean | null>
const capsLockState2 = useKeyModifier('CapsLock', { initial: false }) // Ref<boolean>

类型声明

typescript
export type KeyModifier =
  | "Alt"
  | "AltGraph"
  | "CapsLock"
  | "Control"
  | "Fn"
  | "FnLock"
  | "Meta"
  | "NumLock"
  | "ScrollLock"
  | "Shift"
  | "Symbol"
  | "SymbolLock"
export interface UseModifierOptions<Initial> extends ConfigurableDocument {
  /**
   * 触发修改器状态更新的事件名称
   *
   * @default ['mousedown', 'mouseup', 'keydown', 'keyup']
   */
  events?: WindowEventName[]
  /**
   * 返回的 ref 的初始值
   *
   * @default null
   */
  initial?: Initial
}
export type UseKeyModifierReturn<Initial> = Ref<
  Initial extends boolean ? boolean : boolean | null
>
export declare function useKeyModifier<Initial extends boolean | null>(
  modifier: KeyModifier,
  options?: UseModifierOptions<Initial>,
): UseKeyModifierReturn<Initial>

源码

源码演示文档

贡献者

Anthony Fu
一纸忘忧
Jelf
Fernando Fernández
Anthony Fu
Joe Maylor

更新日志

Pending for release...
eddbf - feat: more passive event handlers (#4484)
v12.0.0-beta.1 on 11/21/2024
0a9ed - feat!: drop Vue 2 support, optimize bundles and clean up (#4349)