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,
  });
*/
相关推荐
放下华子我只抽RuiKe521 分钟前
React 从入门到生产(四):自定义 Hook
前端·javascript·人工智能·深度学习·react.js·自然语言处理·前端框架
XinZong1 小时前
OpenClaw 实现双重心跳(Heartbeat)+ clawreach虾聊项目实现
javascript
还有多久拿退休金3 小时前
一张栈的图,治好你面试答不出 script 阻塞的病
前端·javascript
zithern_juejin3 小时前
原型与原型链
javascript
从文处安5 小时前
「前端何去何从」React Router:让单页应用有多页的体验
前端·react.js
008爬虫实战录5 小时前
【码上爬】 题十二:如来神掌 困难, JSVMP加密,使用代理补环境
前端·javascript·node.js
threelab6 小时前
Three.js 数学函数着色器 | 三维可视化 / AI 提示词
javascript·人工智能·着色器
ZC跨境爬虫7 小时前
跟着 MDN 学CSS day_3:(为一个传记页面添加样式)
前端·javascript·css·ui·音视频·html5
夜雪闻竹7 小时前
sql.js WASM 实战:浏览器里跑 SQLite
javascript·sql·wasm
whuhewei7 小时前
React diff算法为什么是DFS,不是BFS
算法·react.js·深度优先