react快捷键hook

react快捷键hook

javascript 复制代码
import {useCallback, useEffect} from 'react';

interface ShortcutConfig {
  keyCode: number;
  altKey?: boolean;
  shiftKey?: boolean;
  ctrlKey?: boolean;
  metaKey?: boolean; // Command键 (Mac)
  onPress: () => void;
  disabled?: boolean;
  preventDefault?: boolean;
  container?: HTMLDivElement | null; // 可选的容器元素,默认为 window
}
export const useKeyboardShortcut = ({
  keyCode,
  altKey = false,
  shiftKey = false,
  ctrlKey = false,
  metaKey = false,
  onPress,
  disabled = false,
  preventDefault = true,
  container,
}: ShortcutConfig) => {
  const handleKeyDown = useCallback(
    (event: KeyboardEvent) => {
      // 检查所有修饰键是否匹配
      if (
        event.keyCode === keyCode &&
        event.altKey === altKey &&
        event.shiftKey === shiftKey &&
        event.ctrlKey === ctrlKey &&
        event.metaKey === metaKey
      ) {
        if (preventDefault) {
          event.preventDefault();
        }

        if (!disabled) {
          onPress();
        }
      }
    },
    [keyCode, altKey, shiftKey, ctrlKey, metaKey, onPress, disabled, preventDefault],
  );

  useEffect(() => {
    if (disabled) return;
    const target = container || window;
    target.addEventListener('keydown', handleKeyDown);

    return () => {
      target.removeEventListener('keydown', handleKeyDown);
    };
  }, [handleKeyDown, disabled, container]);
};
/**
	使用案例
  useKeyboardShortcut({
    keyCode: 88,
    altKey: true,
    shiftKey: false,
    metaKey: false,
    onPress: handleClose,
    disabled: allItems.length === 0,
    container: containerRef.current,
  });
*/
相关推荐
空白诗7 小时前
高级进阶 React Native 鸿蒙跨平台开发:slider 滑块组件 - 进度条与评分系统
javascript·react native·react.js
空白诗7 小时前
高级进阶React Native 鸿蒙跨平台开发:slider 滑块组件 - 音量调节器完整实现
react native·react.js·harmonyos
晓得迷路了7 小时前
栗子前端技术周刊第 116 期 - 2025 JS 状态调查结果、Babel 7.29.0、Vue Router 5...
前端·javascript·vue.js
How_doyou_do7 小时前
执行上下文、作用域、闭包 patch
javascript
叫我一声阿雷吧8 小时前
深入理解JavaScript作用域和闭包,解决变量访问问题
开发语言·javascript·ecmascript
iDao技术魔方8 小时前
深入Vue 3响应式系统:为什么嵌套对象修改后界面不更新?
javascript·vue.js·ecmascript
历程里程碑8 小时前
普通数组-----除了自身以外数组的乘积
大数据·javascript·python·算法·elasticsearch·搜索引擎·flask
摸鱼的春哥8 小时前
春哥的Agent通关秘籍07:5分钟实现文件归类助手【实战】
前端·javascript·后端
念念不忘 必有回响8 小时前
viepress:vue组件展示和源码功能
前端·javascript·vue.js
Amumu121388 小时前
Vue3 Composition API(一)
开发语言·javascript·ecmascript