为了账号安全,请及时绑定邮箱和手机立即绑定

Vue中键盘监听事件(解决element监听键盘不生效)

标签:
Vue.js
Vue监听键盘,直接用@绑定就可以,而且Vue为几个常用的按键提供了别名,不用去查询按键的keyCode
  • 全部的按键别名

.enter
.tab
.delete (捕获“删除”和“退格”键)
.esc
.space
.up
.down
.left
.right

一、input标签绑定esc键

  • <template></template> 中绑定事件

    <input type="text" @keyup.esc="KeyUpEsc">
  • <script></script>中定义事件

    KeyUpEsc:function(){
          alert("监听到esc键")
      }

webp

实现效果截图

二、使用element组件库的el-input标签,绑定delete键

  • <template></template> 中绑定事件

    <el-input v-model="input" placeholder="请输入内容" @keyup.delete.native="KeyUpDelete"></el-input>
  • 为什么这次绑定事件多一个.native修饰符,这个可能是因为element-ui封装了个div在input标签外面,把原来的事件隐藏了,所以如果不加.native的话,按键不会生效

  • <script></script>中定义事件

     KeyUpDelete :function(){
          alert("监听到delete键")
      },

webp

实现效果截图

三、上面两种实现效果是当input标签获取到焦点的时候,才能监听到键盘,下面这种是全局监听enter键,是把监听事件绑定到document上(登录页面常用)

    created: function() {        var _this = this;        document.onkeydown = function(e) {            let key = window.event.keyCode;            if (key == 13) {
                _this.submit();
            }
        };
    },

    methods: {        submit: function() {            alert("监听到enter键");
        },
   }

webp

实现效果截图



作者:神仙哥哥卿洋
链接:https://www.jianshu.com/p/f2172afaf9bf


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消