Vue键盘事件的使用
创始人
2024-05-30 16:03:58
0

前言

在vue中,我们经常会用到键盘事件,不管是我们按下某个键,其实都是一次键盘事件的调用,下面就介绍下Vue中的键盘事件

先写一段代码,这里我选择的键盘事件是keyup,当然用keydown也是没问题的

在这里插入图片描述

在这里插入图片描述

问题来了,什么按键都能触发事件,我们期望的是只能按下回车键才能打印输入的值, 那么:如何判断回车呢?

传统方式判断案件编码

最原始的办法,就是判断按键编码

           showInfo(e){// 如果按键没有按回车,就不打印日志 13就是回车键的编码if(e.keyCode!==13){return;}console.log(e.target.value)}   

在这里插入图片描述

查看页面,我们发现功能已经实现了,我们输入内容必须按下回车,才能打印日志,按其他键都不好使

在这里插入图片描述

vue判断案件编码

在vue中,我们不用亲自判断按键编码,我们只需要在事件后面跟上修饰.enter就代表回车了

 

在这里插入图片描述

在这里插入图片描述

vue中9个按键别名

通常称enter为别名,vue给按键都起了别名,一共有九个:
回车:enter
删除(退格):delete
退出:esc
空格:space
换行:tab(特殊,必须配合keydown使用)
上:up
下:down
左:left
右:right

vue自定义绑定按键

如果我们想要绑定的按键不在vue提供的9个按键内,那该怎么办呢?比如我就想要用CapsLock(切换大小写)

首先要知道:键盘上任意的一个按键都有自己的按键和编码

我们可以通过key和keyCode分别获取案件名称和对应的编码

在这里插入图片描述

按下键盘的caps,看到控制台提示按键叫CapsLock,对应的编码为20

在这里插入图片描述

多个单词按键特殊处理

上面我们已经知道了,大小写的按键叫CapsLock,那么我们直接使用,CapsLock是否就能直接限制只能大小写按键呢?

在这里插入图片描述

答案是否定的,按下caps切换大小写没有任何反应

在这里插入图片描述

这里就要强调下了,在vue中这种多个单词的情况下,不能写原生的按键名称,要把首字母的大写全部换成小写,并且直接用-进行拼接


在这里插入图片描述

再次测试解决问题,这种情况较少,我们需要格外注意

在这里插入图片描述

不是全部的按键都能绑定事件的,个别特殊按钮也是不行的

5个特殊按键

在一些按键中,因为特殊的机制,需要我们特殊处理,我们简单介绍下

tab按键

我们都知道,tab按键可以转移光标,这个按键比较特殊,我们不能直接使用tab去绑定事件,不然会发现是无效的,只会切换光标

在这里插入图片描述

在这里插入图片描述

所以当使用tab的时候,不应该使用keyup,应该使用keydown

在这里插入图片描述

发现虽然光标已经移走了,但是已经实现了我们的需求

在这里插入图片描述

ctrl,alt,shift,meta(window)按键

这四个按键我们一般称为系统修饰键(用法比较特殊),我们一般使用keydown而不是keyup按键

1 配合keyup使用:按下修饰键的同时,再按下其他键,随后释放其他键,事件才能触发

2 配合keydown使用:正常触发事件

如果我们非要用keyup事件,需要配合一个其他按键,任意的都行,我们以ctrl为例

在这里插入图片描述

我这里按的是ctrl+Q 触发事件

在这里插入图片描述

如果是使用keydown,就没有这么麻烦了,我们直接按下ctrl即可

在这里插入图片描述

我这里只按下了ctrl

在这里插入图片描述

通过键玛绑定按键事件

上面我们的案例都是绑定按键名,我们知道每一个按键都有对应的键码,我们可以通过键码去绑定事件,我这里以enter(回车)为例,它的键码是13

在这里插入图片描述

也是没有任何问题的

在这里插入图片描述

但是通过键码绑定按键事件的方式已经不推荐使用了,原因如下

部分浏览器已经不支持按键编码绑定事件的格式的,而且这种方式正常被废除,不同的电脑的按键有可能是不同的,也会造成不必需要的麻烦

所以我们应该少用甚至不用这种方式,应该使用按键名称绑定事件

在这里插入图片描述

自定义按键别名

我们上述使用的按键名称,比如enter回车,都是vue帮我们定义的,我们也可以自定义一些别名

比如我不想用enter,就想叫huiche,这时候怎么处理呢?

其实vue也给我们提供了解决方法,我们可以使用Vue.config.keyCodes去定义,语法如下

  // 定义了一个叫huiche的别名按键,这个按键对应的键码是13,也就是enter回车键Vue.config.keyCodes.huiche=13 

在这里插入图片描述

按下enter回车键,效果一样的

在这里插入图片描述

但是这种方式也是不推荐的,一般vue给我们提供的别名就够用了,代码如下:


初始vue

欢迎学习:{{name}}

多个按键拼接使用

这时候有个需求,必须是按下ctrl+y只会才能打印日志,那么这时候我们可以这样,在ctrl后拼接y

 // ctrl+y一起按 

在这里插入图片描述

发现没有问题,只能是ctrl+y才会触发事件打印日志

在这里插入图片描述

相关内容

热门资讯

ios系统和安卓系统游戏互通,... 哎呀呀,小伙伴们,你们有没有想过,为什么我们玩的游戏有时候在iOS和安卓系统上不能一起玩呢?是不是觉...
安卓系统改全网通,轻松实现全网... 你有没有想过,你的安卓手机是不是也能变身成为全网通的小超人呢?没错,就是那种不管走到哪里,都能轻松连...
安卓系统开发java,基于Ja... 你有没有想过,那些在手机上玩得不亦乐乎的游戏,还有那些帮你解决生活小困扰的应用,它们是怎么诞生的呢?...
华为安卓系统彩蛋7.0,趣味迷... 哇,你知道吗?华为的安卓系统7.0里竟然藏了一个超有趣的彩蛋!是不是听起来就让人心动呢?别急,让我带...
ios安卓双系统教程,体验跨平... 你有没有想过,你的手机可以同时拥有iOS和安卓两个系统呢?没错,就是那种一边玩着苹果的清新界面,一边...
安卓系统微信来电,生活更便捷 亲爱的手机控们,你们有没有遇到过这种情况:手机里微信响个不停,可就是没声音?是不是觉得有点尴尬,又有...
手机更新内容安卓系统,性能飞跃... 你有没有发现,手机更新就像是我们生活中的小惊喜呢?有时候,它悄无声息地来,有时候,它带着满满的期待。...
安卓系统下片安全吗,守护隐私防... 你有没有想过,在安卓手机上下载电影和电视剧,这事儿安全吗?咱们都知道,现在网络世界复杂多变,一不小心...
安卓系统如何秒变ios系统,安... 你有没有想过,把你的安卓手机变成苹果iOS系统,体验一下那流畅的触感和独特的系统设计呢?虽然官方并不...
安卓系统在哪设置时间,快速定位... 手机时间不准了?别急,让我来带你一探究竟,看看安卓系统里那些隐藏的小秘密,教你轻松设置时间!一、时间...
怎么锁软件安卓系统,轻松保护隐... 你有没有想过,你的安卓手机里那些珍贵的软件,要是突然被别人随意打开,那可真是让人头疼呢!别担心,今天...
安卓系统模拟移动键,便捷操作新... 你有没有想过,你的安卓手机其实是个超级英雄?它不仅能帮你拍照、聊天、听音乐,还能变成你的私人助手,帮...
安卓升级系统出错了,探寻系统升... 哎呀呀,亲爱的手机控们,你们有没有遇到过这种情况:手机更新了新系统,结果却发现各种小问题层出不穷,让...
苹果安卓系统切换软件,苹果安卓... 你有没有想过,你的安卓手机也能摇身一变,成为苹果手机的模样呢?没错,就是那种看起来酷炫、操作流畅的感...
harmonyos能代替安卓系... 亲爱的读者们,你是否也像我一样,对华为的HarmonyOS系统充满了好奇?最近,关于HarmonyO...
安卓系统优势在哪找到,打造高效... 你有没有想过,为什么安卓系统这么受欢迎呢?它就像一个万能的魔法盒,里面装满了各种神奇的功能和便利。今...
安卓调用系统相机代码,系统相机... 你有没有想过,手机里的相机功能竟然可以这么强大?没错,就是那个我们每天都会用到的小玩意儿——系统相机...
安卓系统和webos系统哪个好... 亲爱的读者们,你是否在为选择智能电视系统而烦恼?安卓系统和WebOS系统哪个更好?别急,今天我就来给...
安卓系统与ios系统相同软件,... 你有没有想过,同样是手机,为什么安卓和iOS系统下的软件看起来、用起来感觉就是不一样呢?今天,就让我...
安卓更新不到新系统,探索魅族手... 亲爱的手机主人,你是否也遇到了这样的烦恼:明明手机已经卡得像蜗牛,却怎么也更新不到最新的系统呢?别急...