Vue框架学习笔记——键盘事件

文章目录


前文提要

本人仅做个人学习记录,如有错误,请多包涵


键盘事件(并不是所有按键都能绑定键盘事件)

如何设置键盘事件,代码如下(keydown可以改为keyup):

html 复制代码
<body>
  <div id="box">
    键盘事件:<input type="text" @keydown.enter="showInfo">
  </div>
  <script type="text/javascript">
    Vue.config.productionTip = false
    const vm = new Vue({
      el: '#box',
      methods: {
        showInfo() {
          console.log('触发了')
        }
      }
    })
  </script>
</body>

当你点击输入框之后,按下回车键,就会在控制台输出'触发了'

常用的按键

回车已经介绍过了,如果你将上文代码中的enter改为delete,那么当你选中了输入框的时候,按下backspace(退格)和delete(删除)都会触发键盘事件。

不同的tab和四个按键

其中tab键有所不同,你使用keyup触发事件是无效的,只能使用keyup

同样特殊的还有一下四个按键。

验证代码如下:

当你选中输入框,按下和松开alt的时候并不会触发键盘事件。

当你按住alt,并且按下其他按键的时候,才会触发键盘事件,调用回调函数。

keyCode绑定键盘事件(不推荐)

当你不知道这个按键的名字的时候,也可以用按键对应的数值来绑定键盘事件

可以通过下述代码获取按键对应的keyCode,代码如下:

html 复制代码
<body>
  <div id="box">
    键盘事件:<input type="text" @keydown.caps-lock="showInfo">
  </div>
  <script type="text/javascript">
    Vue.config.productionTip = false
    const vm = new Vue({
      el: '#box',
      methods: {
        showInfo() {
          console.log(event.key,event.keyCode)
        }
      }
    })
  </script>
</body>

向CapLock这种由两个单词组成的按键,需要将单词首字母全部变为小写,且用'-'隔开才能使用。

有图可知,这个CapsLock按键对应的key值是20,我们也就可以用如下代码代替上文代码中的这个部分,也可以起到相同的效果。

但是不推荐,因为key值是被废弃的特性,可以在该链接中看见:
KeyboardEvent.keyCode

keyCode绑定键盘事件,代码如下:

html 复制代码
<div id="box">
    键盘事件:<input type="text" @keydown.20="showInfo">
</div>

Vue.config.keyCode.自定义键名 = 键码

建码就是按键对应的keyCode,enter(回车)对应13。

代码如下:

html 复制代码
<body>
  <div id="box">
    键盘事件:<input type="text" @keydown.huiche="showInfo">
  </div>
  <script type="text/javascript">
    Vue.config.productionTip = false
    const vm = new Vue({
      el: '#box',
      methods: {
        showInfo() {
          console.log(event.key,event.keyCode)
        }
      }
    })
    Vue.config.keyCodes.huiche = 13;
  </script>
</body>

自定义键名'huiche',使得输入框绑定回车键

神奇的猜想

div标签和click.enter

html 复制代码
<div @click.enter="showInfo" style="background-color:red">点我触发事件</div>

鼠标点击div标签,触发事件:

此时,按下或是按住都不会触发键盘事件,都不会在控制台输出'触发了'

button标签和click.enter

如果将代码改为:

html 复制代码
<button @click.enter="showInfo">点我触发事件</button>

鼠标点击按钮,能够触发事件:

这很正常,因为触发了鼠标点击事件。

如果你的鼠标放在按钮以外的位置,按下回车键的时候,无法在控制台输出1,这很正常。

但是如果,你把鼠标放在按钮之上(不点击,只是放着),按下回车键,则会触发事件,在控制台输出1,这就不是很正常了。

所以,键盘事件最好还是配合keydown和keyup这些事件进行使用

且这些元素能够被"选中",能够让系统知道你此时选择了这个元素。


至此,结束。

如果你觉得这篇文章写的不错,多多点赞~收藏吧!

相关推荐
Sheldon一蓑烟雨任平生5 小时前
Vue3 插件(可选独立模块复用)
vue.js·vue3·插件·vue3 插件·可选独立模块·插件使用方式·插件中的依赖注入
容器( ु⁎ᴗ_ᴗ⁎)ु.。oO6 小时前
Magentic-ui 学习
学习
_李小白6 小时前
【OPENGL ES 3.0 学习笔记】延伸阅读:VAO与VBO
笔记·学习·elasticsearch
鱼与宇7 小时前
苍穹外卖-VUE
前端·javascript·vue.js
微露清风7 小时前
系统性学习C++-第九讲-list类
c++·学习·list
用户47949283569157 小时前
Safari 中文输入法的诡异 Bug:为什么输入 @ 会变成 @@? ## 开头 做 @ 提及功能的时候,测试同学用 Safari 测出了个奇怪的问题
前端·javascript·浏览器
摇滚侠7 小时前
Spring Boot3零基础教程,Spring Boot 应用打包成 exe 可执行文件,笔记91 笔记92 笔记93
linux·spring boot·笔记
开开心心就好7 小时前
电子报纸离线保存:一键下载多报PDF工具
网络·笔记·macos·pdf·word·音视频·phpstorm
朝新_7 小时前
【SpringMVC】详解用户登录前后端交互流程:AJAX 异步通信与 Session 机制实战
前端·笔记·spring·ajax·交互·javaee
裴嘉靖8 小时前
Vue 生成 PDF 完整教程
前端·vue.js·pdf