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>

效果演示


下一篇

相关推荐
时光足迹9 小时前
uni-app 里把加密视频嵌入页面播放?我分析了 4 种方案,只有 1 种接近完美
前端·vue.js·uni-app
时光足迹9 小时前
JPush UniApp UTS 插件完全参考手册:API、事件与厂商通道一网打尽
vue.js·ios·uni-app
时光足迹9 小时前
极光推送全攻略(下):uni-app 代码实现与 iOS 排查实战
vue.js·ios·uni-app
To_OC9 小时前
万字解析《JS 语言精粹》之第五章:继承 5 大核心精髓(JS 原型核心)
前端·javascript·代码规范
疯狂的魔鬼10 小时前
一个"懂分寸"的文本省略组件是怎样炼成的
前端·vue.js·设计
裕波11 小时前
AI 正在重写应用开发。Vue 与 Vite,给出新的答案。
javascript·vue.js
妙码生花11 小时前
现代前端的极致性能 icon 加载方案(死磕成功版)
前端·vue.js·typescript
kyriewen12 小时前
折腾了半年 AI 编程工作流,最后发现效率瓶颈是桌上那块屏幕
前端·javascript·ai编程
用户21366100357214 小时前
Vue2脚手架工程化与Axios集成
前端·vue.js
用户831348593069814 小时前
Cesium实现黄昏效果:按钮一键控制打开/关闭黄昏效果,滑块拖动实时控制黄昏浓烈度
vue.js·cesium