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,
  });
*/
相关推荐
Lee川1 小时前
🚀《JavaScript 灵魂深处:从 V8 引擎的“双轨并行”看执行上下文的演进之路》
javascript·面试
比特鹰1 小时前
手把手带你用Flutter手搓人生K线
前端·javascript·flutter
大雨还洅下1 小时前
前端JS: 数组扁平化
javascript
奔跑路上的Me1 小时前
前端导出 Word/Excel/PDF 文件
前端·javascript
bluceli1 小时前
JavaScript异步编程深度解析:从回调到Async Await的演进之路
前端·javascript
SuperEugene1 小时前
路由与布局骨架篇:布局系统 | 头部、侧边栏、内容区、面包屑的拆分与复用
前端·javascript·vue.js
代码煮茶1 小时前
前端网络请求实战 | Axios 从入门到封装(拦截器 / 错误处理 / 重试)
javascript
进击的尘埃1 小时前
组合式函数 Composables 的设计模式:如何写出可复用的 Vue3 Hooks
javascript
进击的尘埃2 小时前
浏览器渲染管线深度拆解:从 Parse HTML 到 Composite Layers 的每一帧发生了什么
javascript
大雨还洅下2 小时前
前端手写: Promise封装Ajax
javascript