el-input绑定键盘按键--按键修饰符

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>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值