js简单封装监听快捷键对象示例及使用

 更新时间:2023年08月08日 14:43:06   作者:littlesunn  
这篇文章主要为大家介绍了js简单封装监听快捷键对象及使用示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

js简单封装一个监听快捷键的对象

export default class Shortcuts {
    keyCodeMap = new Map([
        ["0", 48],
        ["1", 49],
        ["2", 50],
        ["3", 51],
        ["4", 52],
        ["5", 53],
        ["6", 54],
        ["7", 55],
        ["8", 56],
        ["9", 57],
        ["A", 65],
        ["B", 66],
        ["C", 67],
        ["D", 68],
        ["E", 69],
        ["F", 70],
        ["G", 71],
        ["H", 72],
        ["I", 73],
        ["J", 74],
        ["K", 75],
        ["L", 76],
        ["M", 77],
        ["N", 78],
        ["O", 79],
        ["P", 80],
        ["Q", 81],
        ["R", 82],
        ["S", 83],
        ["T", 84],
        ["U", 85],
        ["V", 86],
        ["W", 87],
        ["X", 88],
        ["Y", 89],
        ["UP", 38],
        ["RIGHT", 39],
        ["DOWN", 40],
        ["LEFT", 37],
        ["CTRL", 17],
        ["SHIFT", 16],
        ["ALT", 18],
        ["SPACE", 32],  // 空格键
    ]);
    constructor(keyNames = [], callback, isPreventDefault = false) {
        this.destroy();
        this.isPreventDefault = isPreventDefault;
        this.keyNames = keyNames;
        this.callback = callback;
        this.initEventListener()
    }
    initEventListener() {
        document.addEventListener("keyup", this.handleKeyup.bind(this))
    }
    destroy() {
        document.removeEventListener("keyup", this.handleKeyup.bind(this))
    }
    handleKeyup(e) {
        this.isPreventDefault && e.preventDefault();  // 是否阻止默认行为
        let conditions = []
        if (Array.isArray(this.keyNames)) {  // 数组是组合键
            this.keyNames.forEach(code => {
                let strCode = code.toString().toUpperCase();
                switch (strCode) {
                    case "CTRL":
                        conditions.push(e.ctrlKey)
                        break;
                    case "SHIFT":
                        conditions.push(e.shiftKey)
                        break;
                    case "ALT":
                        conditions.push(e.altKey)
                        break;
                    default:
                        conditions.push(this.keyCodeMap.get(strCode) == e.keyCode)
                        break;
                }
            })
        }else {
            let strCode = this.keyNames.toString().toUpperCase();
            if(strCode == e.keyCode){
                conditions.push(true); 
            }
        }
        if (conditions.every(item => item)) {
            this.callback && this.callback()
        }
    }
}

使用

    new Shortcuts(["ctrl", "q"], ()=>{  //组合键
      console.log(111);
    });
    new Shortcuts("q", ()=>{  // 单键
      console.log(111);
    });

以上就是js简单封装监听快捷键对象示例及使用的详细内容,更多关于js封装监听快捷键对象的资料请关注脚本之家其它相关文章!

相关文章

  • fabric.js图层功能独立显隐 添加 删除 预览实现详解

    fabric.js图层功能独立显隐 添加 删除 预览实现详解

    这篇文章主要为大家介绍了fabric.js图层功能独立显隐 添加 删除 预览实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • 微信小程序 省市区选择器实例详解(附源码下载)

    微信小程序 省市区选择器实例详解(附源码下载)

    这篇文章主要介绍了微信小程序 省市区选择器实例详解的相关资料,区域间手势滑动切换,标题栏高亮随之切换,反之亦然;当前选中标题红色高亮;回到前一级点击某区域后,清空子代的区域,需要的朋友可以参考下
    2017-01-01
  • JavaScript 对象管家 Proxy

    JavaScript 对象管家 Proxy

    这篇文章主要为大家介绍了JavaScript对象管家Proxy使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • JS前端面试数组扁平化手写flat函数示例

    JS前端面试数组扁平化手写flat函数示例

    这篇文章主要为大家介绍了JS前端面试数组扁平化手写flat函数示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • JS精髓原型链继承及构造函数继承问题纠正

    JS精髓原型链继承及构造函数继承问题纠正

    这篇文章主要为大家介绍了JS精髓原型链继承及构造函数继承问题纠正,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • 微信小程序 loading 组件实例详解

    微信小程序 loading 组件实例详解

    这篇文章主要介绍了微信小程序 loading 组件实例详解的相关资料,需要的朋友可以参考下
    2016-09-09
  • 微信支付 JS API支付接口详解

    微信支付 JS API支付接口详解

    本文是对微信支付 JS API支付接口介绍,并附代码实例,在开发过程中具有参考价值,希望能帮助到需要的朋友
    2016-07-07
  • 前端使用xlsx库导出带有样式的excel文件

    前端使用xlsx库导出带有样式的excel文件

    这篇文章主要为大家介绍了前端使用xlsx库导出带有样式的excel文件示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • 深入理解函数执行上下文 this

    深入理解函数执行上下文 this

    这篇文章主要为大家介绍了深入理解函数执行上下文 this示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 解析Javascript设计模式Revealing Module 揭示模式单例模式

    解析Javascript设计模式Revealing Module 揭示模式单例模式

    这篇文章主要为大家解析了Javascript设计模式Revealing Module 揭示模式及Singleton单例模式示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08

最新评论