详解输入框事件 blur 与 change 的差异

网友投稿 1860 2022-05-28

详解输入框事件 blur 与 change 的差异

一、前言

blur与change事件在绝大部分情况下表现都非常相似,输入结束后,离开输入框,会先后触发change与blur,唯有两点例外。

1. 没有进行任何输入时,不会触发change。

在这种情况下,输入框并不会触发change事件,但一定会触发blur事件。在判断表单修改状态时,这种差异会非常有用,通过change事件能轻易地找到哪些字段发生了变更以及其值的变更轨迹。

2. 输入后值并没有发生变更。

这种情况是指,在没有失焦的情况下,在输入框内进行返回的删除与输入操作,但最终的值与原值一样,这种情况下,keydown、input、keyup、blur都会触发,但change依旧不会触发。

二、延伸阅读

vue运行为v-on在监听键盘事件时,添加了特殊的键盘修饰符:

vue还非常贴心地给出了常用按键的别名,这样就不必去记keyCode ~ ~

上面代码,还可以在这样写:

全部的键盘别名如下:

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

还有一些组合按键:

.ctrl .alt .shift .meta(window系统下是window键,mac下是command键)

Alt + C :

Ctrl + Click :

点我

注意:如果使用封装组件的话,比如elementUI,这个时候使用按键修饰符需要加上.native。

比如:

@keyup.enter.native: 该事件与v-on:input事件的区别在于:input事件是实时监控的,每次输入都会调用,而@keyup.enter事件则是在pc上需要点击回车键触发,而在手机上则是需要点击输入键盘上的确定键才可触发。

三、拓展阅读

《Vue进阶(幺幺叁):关于vue.js element ui 表单验证 this.$refs[formName].validate()的问题》

《Vue进阶(幺肆陆):vue 输入框中按enter键实现搜索或表单提交》

Vue

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:【AI前沿动态】性能最强的目标检测算法
下一篇:Unity 之 ShaderGraph Procedural节点解析汇总
相关文章