0

0

使用 JavaScript 类等待特定按键

碧海醫心

碧海醫心

发布时间:2025-10-14 09:17:32

|

686人浏览过

|

来源于php中文网

原创

使用 javascript 类等待特定按键

本文将介绍如何在 JavaScript 类中实现等待特定按键事件触发后再继续执行的功能。我们将通过 Promise 和事件监听器来实现这一目标,并提供两种不同的实现方式:一种基于 Promise,另一种不使用 Promise,而是直接绑定事件监听器。通过本文,你将学习到如何在类中正确地处理异步事件,并避免常见的 `this` 指向问题。

使用 Promise 实现按键等待

一种常见的实现方式是使用 Promise 来处理异步的按键事件。这种方法允许你将按键等待封装在一个可等待的函数中,从而使代码更加清晰和易于管理。

以下是一个使用 Promise 实现按键等待的 JavaScript 类的示例:

class exampleClass {
    async waitForKeyPress() {
        return new Promise((resolve) => {
            const listener = (e) => {
                if(e.key === "z") {
                    window.removeEventListener("keydown", listener);
                    resolve();
                }
            }
            window.addEventListener("keydown", listener);
        });
    }

    async doStuff() {
        await this.waitForKeyPress();
        console.log("correct key pressed");
        //do stuff
    }
}

let exampleObject = new exampleClass();
exampleObject.doStuff();

代码解释:

立即学习Java免费学习笔记(深入)”;

  1. waitForKeyPress() 方法: 这个方法返回一个 Promise。当用户按下 "z" 键时,Promise 将会被 resolve。
  2. listener 函数: 这是一个事件监听器函数,它监听 keydown 事件。
    • 当检测到按下的键是 "z" 时,它会首先移除自身的事件监听器,以防止重复触发。
    • 然后,它会调用 resolve() 函数,从而 resolve Promise。
  3. doStuff() 方法: 这个方法使用 await 关键字来等待 waitForKeyPress() 方法返回的 Promise 被 resolve。一旦 Promise 被 resolve (即用户按下了 "z" 键),它将继续执行后续的代码。
  4. 事件监听器移除: 只有当用户按下正确的键(这里是 "z" 键)时,才移除事件监听器。 原始代码中,如果按下的键不是 "z",会递归调用 waitForKeyPress(),导致多次添加监听器,并且没有正确移除之前的监听器。

注意事项:

  • 使用 window.removeEventListener 而不是 document.body.removeEventListener,因为监听器是添加到 window 上的。
  • 确保在 Promise resolve 后移除事件监听器,避免内存泄漏和不必要的事件触发。

不使用 Promise 实现按键等待

另一种方法是不使用 Promise,而是直接在类的构造函数中绑定事件监听器。这种方法可能更简洁,但需要更小心地处理 this 的指向问题。

逍遥内容管理系统(Carefree CMS)1.3.0
逍遥内容管理系统(Carefree CMS)1.3.0

系统简介逍遥内容管理系统(CarefreeCMS)是一款功能强大、易于使用的内容管理平台,采用前后端分离架构,支持静态页面生成,适用于个人博客、企业网站、新闻媒体等各类内容发布场景。核心特性1、模板套装系统 - 支持多套模板自由切换,快速定制网站风格2、静态页面生成 - 一键生成纯静态HTML页面,访问速度快,SEO友好3、文章管理 - 支持富文本编辑、草稿保存、文章属性标记、自动提取SEO4、全

下载

以下是一个不使用 Promise 实现按键等待的 JavaScript 类的示例:

class exampleClass {
    constructor() {
        // the reason for this line is because "this"
        // inside doStuff will be window instead of
        // the class itself.
        this.doStuff = this.doStuff.bind(this)
        window.addEventListener("keydown", this.doStuff);
    }

    doStuff(e) {
        if(e.key !== 'z') return
        window.removeEventListener("keydown", this.doStuff)
        console.log("correct key pressed");
        //do stuff
    }
}

let exampleObject = new exampleClass();

代码解释:

立即学习Java免费学习笔记(深入)”;

  1. constructor() 方法:
    • 使用 this.doStuff = this.doStuff.bind(this) 来确保 doStuff 方法中的 this 指向类的实例,而不是 window 对象。 这是因为在事件监听器中,this 的默认指向是绑定事件的元素(这里是 window)。
    • 将 doStuff 方法绑定到 keydown 事件。
  2. doStuff() 方法:
    • 检查按下的键是否是 "z"。如果不是,则直接返回,不执行任何操作。
    • 如果是 "z",则移除事件监听器,并执行后续的代码。

注意事项:

  • 使用 bind(this) 来确保 this 指向正确。 否则,在事件处理函数中访问类的属性或方法时可能会出错。
  • 同样,确保在检测到正确的按键后移除事件监听器。

总结

本文介绍了两种在 JavaScript 类中实现等待特定按键事件的方法。 使用 Promise 的方法更加灵活,并且可以更好地处理异步操作。 不使用 Promise 的方法可能更简洁,但需要更小心地处理 this 的指向问题。 在选择使用哪种方法时,请根据你的具体需求和代码风格进行权衡。 无论选择哪种方法,都要确保正确地添加和移除事件监听器,以避免内存泄漏和不必要的事件触发。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
promise的用法
promise的用法

“promise” 是一种用于处理异步操作的编程概念,它可以用来表示一个异步操作的最终结果。Promise 对象有三种状态:pending(进行中)、fulfilled(已成功)和 rejected(已失败)。Promise的用法主要包括构造函数、实例方法(then、catch、finally)和状态转换。

306

2023.10.12

html文本框类型介绍
html文本框类型介绍

html文本框类型有单行文本框、密码文本框、数字文本框、日期文本框、时间文本框、文件上传文本框、多行文本框等等。详细介绍:1、单行文本框是最常见的文本框类型,用于接受单行文本输入,用户可以在文本框中输入任意文本,例如用户名、密码、电子邮件地址等;2、密码文本框用于接受密码输入,用户在输入密码时,文本框中的内容会被隐藏,以保护用户的隐私;3、数字文本框等等。

406

2023.10.12

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

8

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

8

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

6

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

1

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

20

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

17

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

18

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号