当前位置: 首页 > news >正文

50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | EventKey Codes(键盘码)

📅 我们继续 50 个小项目挑战!—— EventKeyCodes 组件

仓库地址:https://github.com/SunACong/50-vue-projects

项目预览地址:https://50-vue-projects.vercel.app/

在这里插入图片描述

使用 Vue 3 的 <script setup> 语法结合 TailwindCSS 构建一个简单的键盘监听组件,展示用户按下任意键时的 keyCodekeycode 信息。

🎯 组件目标

  • 监听用户的键盘输入事件。
  • 展示按下的键码(keyCode)、字符(key)和物理键位(code)。
  • 使用 TailwindCSS 美化 UI,保持简洁现代的设计风格。
  • 提供清晰的交互反馈:初始提示信息与按键后的数据展示切换。

⚙️ 技术实现点

技术点描述
Vue 3 Composition API (<script setup>)使用响应式变量管理组件状态
事件监听 (window.addEventListener)监听全局的 keydown 事件
条件渲染 (v-if, v-else)判断是否已按下按键以切换视图
TailwindCSS 响应式布局使用类名快速构建美观的 UI

🧱 组件实现

模板结构 <template>

<template><div class="flex h-screen items-center justify-center text-white"><div v-if="noPressKey" class="btn key border-2">Press any key to get the keyCode</div><div v-else class="flex gap-8 text-white"><div class="btn w-56 border-2 text-2xl">KeyCode: {{ handleKeyDown.keyCode }}</div><div class="btn w-56 border-2 text-2xl">Key: {{ handleKeyDown.key }}</div><div class="btn w-56 border-2 text-2xl">Code: {{ handleKeyDown.code }}</div></div></div>
</template>

脚本逻辑 <script setup>

<script setup>
import { ref } from 'vue'const noPressKey = ref(true)const handleKeyDown = ref({keyCode: 0,key: '',code: '',
})// 监听键盘事件,按下任意键时显示键码
window.addEventListener('keydown', (event) => {noPressKey.value = falsehandleKeyDown.value.keyCode = event.keyCodehandleKeyDown.value.key = event.keyhandleKeyDown.value.code = event.code
})
</script>

💡 注意事项:

  • 由于 window.addEventListener 是副作用操作,在生产环境中建议使用 onMounted 生命周期钩子来绑定事件,并在 onUnmounted 中移除监听器,避免内存泄漏。
  • 可以进一步封装为可复用的自定义 Hook,例如 useKeyboardEvent()

🔍 重点效果实现

动态切换视图

通过 v-ifv-else 控制是否已经按下键盘:

  • 初始状态显示“Press any key…”
  • 一旦触发 keydown 事件,隐藏提示并展示三个包含键值的按钮。

键盘事件监听

使用原生 JavaScript 的 window.addEventListener('keydown') 来监听用户按键,并将返回的 keyCodekeycode 更新到响应式对象 handleKeyDown 中,从而触发模板更新。

window.addEventListener('keydown', (event) => {noPressKey.value = falsehandleKeyDown.value.keyCode = event.keyCodehandleKeyDown.value.key = event.keyhandleKeyDown.value.code = event.code
})

🎨 TailwindCSS 样式重点讲解

类名作用
flex启用弹性盒子布局
h-screen高度为整个视口高度
items-center垂直居中对齐
justify-center水平居中对齐
text-white文字颜色为白色
border-2边框宽度为 2px
w-56宽度为 8rem(即 224px)
text-2xl字体大小为 1.5rem
gap-8flex 子元素之间间隔为 2rem

这些类名帮助我们快速构建出一个居中的响应式布局,并确保视觉上的一致性和美观性。


📁 常量定义 + 组件路由

constants/index.js 添加组件预览常量:

{id: 11,title: 'Event KeyCodes',image: 'https://50projects50days.com/img/projects-img/11-event-keycodes.png',link: 'EventKeyCodes',},

router/index.js 中添加路由选项:

{path: '/EventKeyCodes',name: 'EventKeyCodes',component: () => import('@/projects/EventKeyCodes.vue'),},

🏁 总结

涵盖 Vue 3 的响应式系统、事件监听机制以及 TailwindCSS 的实用样式类。它不仅是一个教学示例,也可以作为开发调试工具的一部分,用于快速查看键盘事件的数据。


👉 下一篇,我们将完成 FAQ Collapse 组件,一个现代化的折叠Q&A面板!🚀

相关文章:

  • 滑动窗口最大值和最小值
  • 【靶场】xxe漏洞2
  • 【AI论文精读7】GraphRAG
  • 下载WinLibs时UCRT Runtime和MSVCRT Runtime(针对旧版本Windows)的区别
  • 基于“SpringBoot+uniapp的考研书库微信小程序设计与实现7000字论文
  • Monorepo + PNPM 搭建高效多项目管理
  • 云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?
  • 深入浅出掌握 Axios(持续更新)
  • 深入解析 Nacos MCP Router:云原生时代的 MCP 服务调度中枢
  • 云原生核心技术 (4/12): Docker 进阶:镜像优化实战与 Docker Compose 揭秘
  • uniapp+vue2+h5图片下载保存,微信浏览器、非微信浏览器
  • spark数据处理练习题番外篇【上】
  • Spring Boot集成Mina的Socket资源管理:从稳定通信到高性能优化
  • Windows上SSH连接Ubuntu失败
  • XWPFTemplate生成word
  • 置信水平、置信区间
  • 一体系数据平台的进化:基于阿里云 EMR Serverless Spark的持续演进
  • ESP32读取DHT11温湿度数据
  • 带eachers的html转word
  • 笔记 操作系统复习
  • 怎么做展示型网站/emlog友情链接代码
  • 上海响应式网站制作公司/seo网站营销公司哪家好
  • wordpress+dns预读/武汉seo人才
  • 浙江省建设厅网站查询/互联网推广是什么意思
  • 微信网站需要备案吗/by网站域名
  • wordpress 帝国 seo/做网站seo优化