本文主要是介绍Vue进阶(八十七):输入框事件 blur 与 change 的差异,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 一、前言
- 二、延伸阅读
- 三、拓展阅读
人生箴言:感恩
积极 乐观 健康 向上 阳光 大气
一、前言
blur
与change
事件在绝大部分情况下表现都非常相似,输入结束后,离开输入框,会先后触发change
与blur
,唯有两点例外。
1. 没有进行任何输入时,不会触发change。
在这种情况下,输入框并不会触发change
事件,但一定会触发blur
事件。在判断表单修改状态时,这种差异会非常有用,通过change
事件能轻易地找到哪些字段发生了变更以及其值的变更轨迹。
2. 输入后值并没有发生变更。
这种情况是指,在没有失焦的情况下,在输入框内进行返回的删除与输入操作,但最终的值与原值一样,这种情况下,keydown、input、keyup、blur
都会触发,但change
依旧不会触发。
二、延伸阅读
vue
运行为v-on
在监听键盘事件时,添加了特殊的键盘修饰符:
<input v-on:keyup.13="submit">
vue
还非常贴心地给出了常用按键的别名,这样就不必去记keyCode
~ ~
上面代码,还可以在这样写:
<input v-on:keyup.enter="submit"><input @keyup.enter="submit">
全部的键盘别名如下:
.enter.tab.delete (捕获 “删除” 和 “退格” 键).esc.space.up.down.left.right
还有一些组合按键:
.ctrl.alt.shift.meta(window系统下是window键,mac下是command键)
Alt + C
:
<input @keyup.alt.67="doSth">
Ctrl + Click
:
<div @click.ctrl="doSth">点我</div>
注意:如果使用封装组件的话,比如elementUI
,这个时候使用按键修饰符需要加上.native
。
比如:
<el-input v-model="account" placeholder="请输入账号" @keyup.enter.native="search()"></el-input>
@keyup.enter.native
: 该事件与v-on:input
事件的区别在于:input
事件是实时监控的,每次输入都会调用,而@keyup.enter
事件则是在pc上需要点击回车键触发,而在手机上则是需要点击输入键盘上的确定键才可触发。
三、拓展阅读
- 《Vue进阶(幺幺叁):关于vue.js element ui 表单验证 this.$refs[formName].validate()的问题》
- 《Vue进阶(幺肆陆):vue 输入框中按enter键实现搜索或表单提交》
这篇关于Vue进阶(八十七):输入框事件 blur 与 change 的差异的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!