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,
  });
*/
相关推荐
一路向前的月光21 小时前
前端采用electron-hiprint控件实现静默打印
前端·javascript·electron
奶糖 肥晨1 天前
JS自动检测用户国家并显示电话前缀教程|vue uniapp react可用
javascript·vue.js·uni-app
啊花是条龙1 天前
《产品经理说“Tool 分组要一条会渐变的彩虹轴,还要能 zoom!”——我 3 步把它拆成 1024 个像素》
前端·javascript·echarts
青茶3601 天前
【js教程】如何用jq的js方法获取url链接上的参数值?
开发语言·前端·javascript
晴栀ay1 天前
React性能优化三剑客:useMemo、memo与useCallback
前端·javascript·react.js
知其然亦知其所以然1 天前
别再死记硬背了,一篇文章搞懂 JS 乘性操作符
前端·javascript·程序员
json{shen:"jing"}1 天前
08_组件基础
前端·javascript·vue.js
菩提祖师_1 天前
基于VR的虚拟会议系统设计
开发语言·javascript·c++·爬虫
Bigger1 天前
Tauri (25)——消除搜索列表默认选中的 UI 闪动
前端·react.js·weui