vue快速入门(十五)监听键盘事件

注释很详细,直接上代码

上一篇

新增内容

  1. 特定按键监听事件
  2. 全按键监听事件及两种判断方法
    源码
html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <!-- 挂载点 -->
  <div id="root"> 
    <!-- 第一种情况是可以使用几个常见的名称来监视对应按键 -->
    <input type="text" v-model="username" @keyup.enter="clickBtn_1">
    <!-- 第二种情况是可以使用键码来监视对应按键 -->
    <input type="text" v-model="password" @keyup.65="clickBtn_2">
    <!-- 当然也可以在方法里面再判断不同按键的情况 -->
    <input type="text" v-model="age" @keyup="clickBtn_3">
  </div>

  <!-- 导入vue的js代码 -->
  <script src="./lib/vue2.js"></script>

  <script>
    const app = new Vue({// Vue实例
      el: '#root',// 挂载点
      data: {// 数据
        username:'',
        password:'',
        age:''
      },
      methods: {// 方法
        clickBtn_1(){
          console.log(this.username);
        }
        ,
        clickBtn_2(){
          console.log(this.password);
        }
        ,
        clickBtn_3(e){
          // 有两种判断方式,第一种是判断按键名称,第二种是判断按键码
          //注意此处的e.key和e.keyCode的区别
          // 键码对应表可参考:https://www.cnblogs.com/lynallylsx/articles/14480181.html
          if(e.key === 'Enter'){
            console.log('enter');
          }else if(e.keyCode === 65){
            console.log('a');
          }
        }
      }
    })
  </script>
</body>
</html>

效果演示


下一篇

相关推荐
kyriewen2 小时前
用了半年 Claude Code 后,我尝试关掉它写了一周代码——结果比想象中严重
前端·javascript·ai编程
山河木马3 小时前
矩阵专题0-webGL中的矩阵
javascript·webgl·计算机图形学
徐小夕3 小时前
万字拆解 JitWord:企业级实时协同文档底层架构 + 大模型 AI 融合完整实践
前端·vue.js·github
Asize4 小时前
多模态生图:从 Vite 工程化到前端调用 Qwen Image
javascript·人工智能·后端
陳陈陳4 小时前
从Token到Embedding:一篇文章搞懂大模型的「文字数学变形记」
前端·javascript·ai编程
用户938515635074 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
橘子星4 小时前
LLM 无状态架构实践:从原理到代码落地
前端·javascript·人工智能
用户83134859306985 小时前
Cesium实现雾气效果:按钮一键控制打开/关闭雾气效果,滑块拖动实时控制雾气浓度
vue.js·cesium
To_OC5 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
风止何安啊6 小时前
网课倍速痛点解决:一套前端代码实现自由控速播放器
前端·javascript·node.js