JavaScript基础-常用的键盘事件

一、前言

在网页开发中,用户交互 是非常重要的一环。除了鼠标操作之外,键盘事件也是前端开发中最常见的交互方式之一。

JavaScript 提供了多个用于监听和处理键盘输入的事件,例如 keydownkeyupkeypress。掌握这些事件可以帮助我们实现更丰富的用户交互体验,比如:

  • 监听用户按下回车键提交表单;
  • 实现快捷键功能(如 Ctrl + S 保存);
  • 输入框限制只能输入数字或字母;
  • 游戏中的键盘控制逻辑;

本文将详细介绍 JavaScript 中常用的键盘事件,并结合实际案例帮助你快速上手!

二、JavaScript 中的键盘事件类型

事件类型触发时机是否支持字符键
keydown按下任意键时触发✅ 支持所有按键
keyup松开按键时触发✅ 支持所有按键
keypress(已弃用)按下字符键并产生字符输入时触发❌ 不支持功能键(如 Shift、Ctrl 等)

📌 注意:keypress 事件在现代浏览器中已被 弃用(deprecated),建议统一使用 keydownkeyup

三、事件对象(Event Object)

当键盘事件被触发时,会传入一个 事件对象(event),它包含了与该次按键相关的详细信息,常用的属性如下:

属性名含义
key返回按下的键值(字符串),如 'a''Enter''Shift'
keyCode(已弃用)返回按键的 ASCII 编码(整数)
code返回物理按键的标识符(如 'KeyA''Enter'
ctrlKey / shiftKey / altKey判断是否同时按下了 Ctrl/Shift/Alt 键

四、常用键盘事件示例

✅ 示例1:监听 Enter 键提交表单

<input type="text" id="searchInput" placeholder="输入内容后按回车搜索"><script>
document.getElementById("searchInput").addEventListener("keydown", function(event) {if (event.key === "Enter") {alert("你按下了回车键,正在搜索:" + event.target.value);}
});
</script>

📌 应用场景:常用于搜索框、登录框等自动提交场景。

✅ 示例2:监听 Ctrl + S 快捷键保存内容

document.addEventListener("keydown", function(event) {if (event.ctrlKey && event.key === "s") {event.preventDefault(); // 阻止默认保存行为(如弹出保存页面)alert("你按下了 Ctrl + S,正在保存数据...");}
});

📌 技巧说明:

  • 使用 event.ctrlKey 判断是否按住 Ctrl;
  • 使用 event.preventDefault() 可阻止浏览器默认行为。

✅ 示例3:限制输入框只允许输入数字

<input type="text" id="numberInput" placeholder="请输入数字"><script>
document.getElementById("numberInput").addEventListener("keydown", function(event) {const allowedKeys = ['Backspace', 'Tab', 'ArrowLeft', 'ArrowRight', 'Delete'];// 允许删除键、方向键、Tab 等基础操作if (allowedKeys.includes(event.key)) return;// 判断是否为数字键if (!/^[0-9]$/.test(event.key)) {event.preventDefault();}
});
</script>

📌 这个方法可以有效防止用户输入非法字符,提升用户体验。

✅ 示例4:实现方向键控制游戏角色移动

document.addEventListener("keydown", function(event) {switch(event.key) {case "ArrowUp":console.log("向上移动");break;case "ArrowDown":console.log("向下移动");break;case "ArrowLeft":console.log("向左移动");break;case "ArrowRight":console.log("向右移动");break;}
});

📌 应用场景:适用于小游戏、画布动画、地图导航等功能。

五、常见问题与注意事项

问题解答
如何区分大小写?event.key 会根据是否按住 Shift 返回大写或小写
如何判断组合键?使用 event.ctrlKeyevent.shiftKeyevent.altKey
keyCode 和 key 的区别?keyCode 是数字编码,不推荐使用;key 是可读性更强的字符串
如何阻止默认行为?使用 event.preventDefault()
keypress 被弃用了怎么办?统一使用 keydown 或 keyup 替代

六、总结对比表

事件类型适用场景是否推荐使用
keydown检测按键按下、组合键、方向键✅ 推荐
keyup按键释放后执行操作✅ 推荐
keypress字符输入检测❌ 已弃用
input 事件实时获取输入内容变化✅ 配合使用

七、结语

感谢您的阅读!如果你有任何问题或想法,请在评论区留言交流!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/85314.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/85314.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

解决 Android 项目下载依赖缺失导致的问题

解决 Android 项目下载依赖缺失导致的问题 在项目根目录下的 build.gradle 文件中增加下面的代码&#xff1a; buildscript {repositories {...maven {url "https://maven.aliyun.com/repository/jcenter"}maven {url "https://maven.aliyun.com/repository/c…

Clang Code Model: Error: The clangbackend executable “D:\Soft\Qt5.12.12\Tool

Qt Creator->菜单->帮助->关于插件->C>去掉ClangCodeModel勾选->重启Qt Creator 参考&#xff1a;【问题解决】Qt Creator 报错&#xff1a;Clang Code Model: Error: The clangbackend executable_qt clang code model-CSDN博客

高频面试之12 HBase

12 HBase 文章目录 12 HBase12.1 HBase存储结构12.2 HBase的写流程12.3 HBase的读流程12.6 HBase的合并12.7 RowKey设计原则12.8 RowKey如何设计12.9 HBase二级索引原理 12.1 HBase存储结构 架构角色&#xff1a; 1&#xff09;Master 实现类为HMaster&#xff0c;负责监控集群…

Vue3 + TypeScript + Element Plus 表格实例null检查方法

代码分析&#xff1a; // 表格实例对象 const tableRef ref<ElTableExtendedInstance | null>(null); // 表格列配置列表 const columnConfigs ref<IColumnConfig[]>([{ prop: "index", label: "序号", width: 60 },{ prop: "batchNo&…

Neo4j常见语法-unwind

unwind的用法&#xff08;UNWIND 是一个强大的操作符&#xff0c;用于将集合&#xff08;列表、数组&#xff09;展开为多行数据。它类似于关系型数据库中的 UNNEST 或 LATERAL JOIN&#xff0c;是 Cypher 查询中处理集合数据的核心工具&#xff09; &#xff08;1&#xff09;…

JavaEE-Spring-IoCDI

Spring是⼀个开源框架, 他让我们的开发更加简单. 他⽀持⼴泛的应⽤场 景, 有着活跃⽽庞⼤的社区, 这也是Spring能够⻓久不衰的原因. 但是这个概念相对来说, 还是⽐较抽象. ⽤⼀句更具体的话来概括Spring, 那就是: Spring 是包含了众多⼯具⽅法的 IoC 容器 容器是⽤来容纳…

CppCon 2017 学习:10 Core Guidelines You Need to Start Using Now

C.45: 不要定义一个仅仅初始化成员变量的默认构造函数&#xff0c;而是使用类内成员初始化器 如果你有一个默认构造函数&#xff0c;它的唯一作用是给成员变量赋默认值&#xff08;如 1、2、3&#xff09;&#xff0c;这更清晰、简单的方法是直接在成员变量声明时使用类内初始…

Java并发编程实战 Day 28:虚拟线程与Project Loom

【Java并发编程实战 Day 28】虚拟线程与Project Loom 文章内容 在“Java并发编程实战”系列的第28天&#xff0c;我们将聚焦于**虚拟线程&#xff08;Virtual Threads&#xff09;**和 Project Loom&#xff0c;这是 Java 在高并发场景下的一次重大革新。随着现代应用对性能和…

Linux系统移植⑦:uboot启动流程详解-board_init_r执行过程

Linux系统移植⑦&#xff1a;uboot启动流程详解-board_init_r执行过程 在uboot中&#xff0c;board_init_r 是启动流程中的一个关键函数&#xff0c;负责完成板级&#xff08;board-specific&#xff09;的后期初始化工作。以下是关于该函数的详细说明&#xff1a; 1. 函数作…

OpenStack入门体验

1.1云计算概述 相信大家都听到很多的阿里云、腾讯云、百度云等等这些词,那到底什么是云计算?云 计算又能做什么? 1.1.1什么是云计算 云计算(cloud computing)是一种基于网络的超级计算模式,基于用户的不同需求,提供所需的资源,包括计算资源、存储资源、网络资源等。云计算…

RK 安卓10/11平台 HDMI-IN 调试

这篇文章我们介绍一下在安卓9、10、11的版本上&#xff0c;rk平台的hdmi-in功能是如何实现的&#xff0c;下篇文章我们再介绍安卓12之后的版本有了什么变化。希望对在rk平台调试hdmi-in功能的朋友有一些帮助。 目录 &#xff08;1&#xff09;概述 &#xff08;2&#xff09;…

MongoDB学习记录(快速入门)

MongoDB核心 基础概念 数据库 数据库是按照数据结构来组织、存储和管理数据的仓库。在内存中运行的&#xff0c;一旦程序运行结束或者计算机断电&#xff0c;程序运行中的数据都会丢失。我们需要将一些程序运行的数据持久化到硬盘之中&#xff0c;以确保数据的安全性。数据库…

阿里一面:微服务拆分需要考虑什么因素?

要拆分微服务&#xff0c;首先我们要了解微服务拆了会有什么问题&#xff1f;怎么合理拆服务&#xff1f; 拆分服务会带来什么问题&#xff1f; 举个电商系统下单扣库存的例子。 对于单体应用&#xff0c;通讯在进程内部进行&#xff0c;下单方法调用扣库存方法&#xff0c;…

3D高斯泼溅和4D高斯

1.高斯函数 想象你往平静的湖水里扔一块石头&#xff0c;水波会以石头落点为中心向外扩散&#xff0c;形成一个逐渐衰减的圆形波纹。高斯函数的形状就和这个波纹类似&#xff1a; 中心最高&#xff08;石头落点&#xff0c;波峰最强&#xff09;。越往外&#xff0c;高度&…

comfyui插件和comfyui mac安装

mac comfyui安装包 ComfyUI.zip&#xff0c;官方最新0.3.40&#xff0c;如果后续官方有迭代&#xff0c;可以直接通过git更新源码升级 comfyui插件下载&#xff0c;解压放到custom_nodes目录下&#xff0c;包含 comfyui-animatediff-evolved&#xff08;视频插件&#xff09; 和…

面试题SpringCloud

SpringCloud有哪些特征&#xff1f; 分布式/版本化配置服务注册与发现路由服务到服务的调用负载均衡断路器领导选举和集群状态分布式消息传递 SpringCloud核心组件&#xff1f; Eureka 注册中心Ribbon 客户端负载均衡Hystrix&#xff1a; 服务容错处理Feign:声明式Rest客户端Zu…

ASR-PRO语音识别可能出现的问题

ASR-PRO语音识别可能出现的问题 4月份有一天刷到牢大/爱丽丝语音自开关灯设备&#xff0c;心血来潮&#xff0c;博主也是浅尝了一下&#xff0c;由此也总结一下&#xff0c;实现此项目会出现的问题。 在实现爱丽丝开关灯模块时ASRPRO语音识别可能出现的问题如下&#xff1a; …

苍穹外卖--缓存菜品Spring Cache

Spring Cache是一个框架&#xff0c;实现了基于注解的缓存功能&#xff0c;只需要简单地加一个注解&#xff0c;就能实现缓存功能。 Spring Cache提供了一层抽象&#xff0c;底层可以切换不同的缓存实现&#xff0c;例如&#xff1a; ①EHCache ②Caffeine ③Redis 常用注解…

个人简历制作MarkDown模板

MarkDown制作个人简历的模板放在了github上&#xff0c;大家如有需求&#xff0c;请自取&#xff1a; https://github.com/QQQQQQBY/ResumeTemplate 介绍一下此模板的特点&#xff1a; &#x1f338;个人面试期间使用的、整理的简历格式&#xff0c;现在分享给大家。 ⭐简历采…

【MySQL数据库 | 第五篇】DDL操作2

文章目录 当前数据库student的数据数据表操作 - 修改&删除&#x1f4d6;修改操作增加字段&#x1f44f;案例&#xff1a;向数据表student中添加字段 id修改字段的数据类型【只能修改字段的属性】&#x1f44f;案例&#xff1a;将student表中字段age的属性由tinyint unsigne…