vue怎么写键盘事件

vue容许将按键值作为修饰符来应用,如监听回车事件,有两种写法,如下代码:

<input type="text" @keyup.13="console.log($event)"></input>
<input type="text" @keyup.enter="console.log($event)"></input>

但要留神的是:当咱们在在el-input采纳如上两种写法时,他是不失效的。el-input监听不到键盘事件,起因是element-ui是封装组件,所以el标签属于自定义标签,因而触发不了键盘事件。
解决办法:加上.native原生事件修饰符即可。.native:监听组件根元素的原生事件,次要作用是给自定义的组件增加原生事件。
vue与elementUI中给el-input绑定键盘按键代码如下:

<el-input placeholder="店铺名称" clearable v-model="queryObj.shopname" @keyup.enter.native="query">   <template slot="prepend">店铺名称</template></el-input>

罕用按键修饰符

别名修饰符键值修饰符对应按键
.delete.8/.46回格/删除
.tab.9制表
.enter.13回车
.esc.27退出
.space.32空格
.left.37
.up.38
.right.39
.down.40

鼠标按键修饰符

别名修饰符可用版本对应按键
.left2.2.0以上左键
.right2.2.0以上右键
.middle2.2.0以上中键

零碎按键修饰符

别名修饰符可用版本对应按键
.ctrl2.1.0以上Ctrl键
.alt2.1.0以上Alt键
.shift2.1.0以上Shift键
.meta2.1.0以上meta键(Windows零碎上为田键)

对于组合修饰符的应用:
vue为咱们提供了组合修饰符的机制,然而它的应用,必须配合零碎按键修饰符才能够失效。如下是一段测试代码:

<!DOCTYPE html><html><head>  <title></title></head><body><div id="app">  <button @click.ctrl="ctrlClick" @click="together">带上ctrl来找我玩呀</button></div><script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.min.js"></script><script type="text/javascript">  let vm = new Vue({    el: '#app',    methods: {      together(event) {        if (!event.ctrlKey) {          console.log('------------- 我是可恶的分割线呀 -------------')          console.log('$event.ctrlKey:', event.ctrlKey)        } else {          console.log('欢送呀!')        }      },      ctrlClick(event) {        console.log('------------- 我是可恶的分割线呀 -------------')        console.log('$event.ctrlKey:', event.ctrlKey)        console.log('Ctrl你来了呀!')      }    }  })</script></body></html>