从聚焦到失去焦点,以下事件会根据情况,先后判断是否会执行。
onfocus -> 键盘输入 -> onkeydown -> onkeypress -> onkeyup -> oninput -> 失去焦点 -> onchange -> onblur
onfocus 聚焦事件
无论是用户主动的聚焦行为还是代码的强制聚焦,只要是由失去焦点的状态变为聚焦的状态都会触发这一事件。
<template>
<div class="hello">
<input type="text" @focus="onfocus" ref="input1">
<button @click="focusbtn"> foucs </button>
</div>
</template>
<script>
export default {
name: 'HelloWorld',
props: {
msg: String
},
methods: {
onfocus () {
console.log('聚焦执行')
},
focusbtn () {
this.$refs.input1.focus()
}
}
}
</script>
如果本身就是聚焦状态,多次执行聚焦则不会执行
<template>
<div class="hello">
<input type="text" @focus="onfoucs" ref="input1">
<button @click="foucsbtn"> foucs </button>
</div>
</template>
<script>
export default {
name: 'HelloWorld',
props: {
msg: String
},
methods: {
onfoucs () {
console.log('聚焦执行')
},
foucsbtn () {
this.$refs.input1.focus()
this.$refs.input1.focus()
this.$refs.input1.focus()
}
}
}
</script>
<template>
<div class="hello">
<input type="text" @focus="onfoucs" ref="input1">
<button @click="foucsbtn"> foucs </button>
</div>
</template>
<script>
export default {
name: 'HelloWorld',
props: {
msg: String
},
methods: {
onfoucs () {
console.log('聚焦执行')
},
foucsbtn () {
this.$refs.input1.focus()
this.$refs.input1.blur()
this.$refs.input1.focus()
}
}
}
</script>
这也又一次应证了,只有从失去焦点状态变为聚焦,@focus才会执行。
onkeydown 键盘按键按下事件
每一个键的触发都有三个步骤 按下keydown,按住press,抬起keyup,如果有按键输入,keydown会率先触发
<template>
<div class="hello">
<input type="text" @keydown="keydown" @keypress="keypress" @keyup="keyup">
<button @click="foucsbtn"> foucs </button>
</div>
</template>
<script>
export default {
name: 'HelloWorld',
props: {
msg: String
},
methods: {
keydown () {
console.log('按下')
},
keypress () {
console.log('按住')
},
keyup () {
console.log('抬起')
}
}
}
</script>
效果 data:image/s3,"s3://crabby-images/22c32/22c32954cafef4a4e682763fda976bee4f8cdff4" alt="在这里插入图片描述" 但是,如果一直按住按键不松手,keydown也会一直执行
效果 data:image/s3,"s3://crabby-images/c817a/c817a174b4fb5823304128448de9fec079c4242a" alt="在这里插入图片描述"
onkeypress 键盘按键按住事件
每一个键的触发都有三个步骤 按下keydown,按住press,抬起keyup,如果有按键输入,keydown触发后,只要不松开按键,onkeypress 会和onkeydown一起一直触发 data:image/s3,"s3://crabby-images/bce1e/bce1efbf59a6d252516d0ab527a957ccf25724f5" alt="在这里插入图片描述"
onkeyup 键盘按键松开事件
每一个键的触发都有三个步骤 按下keydown,按住press,抬起keyup,如果有按键输入,松开按键的一瞬间会触发一次onkeyup事件,一般来说,keydown和keyup选择一个使用就可以了
oninput 输入值变化事件
当input输入框的值发生变化时,就会触发,一般用户输入内容,会变化很多次,如果不做防抖处理,oninput的事件会执行很多次
<template>
<div class="hello">
<input type="text" @input="onInput" @keydown.enter="onEnter">
</div>
</template>
<script>
export default {
name: 'HelloWorld',
props: {
msg: String
},
methods: {
onEnter () {
console.log('按下enter')
},
onInput () {
console.log('改变了')
}
}
}
</script>
data:image/s3,"s3://crabby-images/77836/7783650a3edc24d50e2e5d4a585514caef7af0b6" alt="在这里插入图片描述" 按下回车键这个行为不会触发oninput事件 data:image/s3,"s3://crabby-images/e13bd/e13bdf0e46dcc3784df1a65aeaf4f4df9de3c69c" alt="在这里插入图片描述"
onchange 失去焦点后的输入值变化事件
当用户输入完成后,无论是按了一下回车键,还是点击了其它地方,或者代码控制失去焦点,都有可能触发onchange 事件。是否触发的另外一个条件就是,与上一次失去焦点的值相比,此时input框内的值是否发生变化,如果变化了,则触发onchange,没有变化则不触发
<template>
<div class="hello">
<input type="text" @change="onchange">
</div>
</template>
<script>
export default {
name: 'HelloWorld',
props: {
msg: String
},
methods: {
onchange () {
console.log('改变了')
}
}
}
</script>
data:image/s3,"s3://crabby-images/f1336/f13362728d1dff275d243bbf294615959e6287e3" alt="在这里插入图片描述"
这里涉及到开发中常用的另外一个问题,当用户敲击回车键后,onchange事件仍有可能触发。如果input框同时绑定了onchange事件,也绑定了对回车键的监听,如果在按下回车键前,input框的值发生变化,这两个事件一定都会触发。
<template>
<div class="hello">
<input type="text" @change="onchange" @keydown.enter="onEnter">
</div>
</template>
<script>
export default {
name: 'HelloWorld',
props: {
msg: String
},
methods: {
onEnter () {
console.log('按下enter')
},
onchange () {
console.log('改变了')
}
}
}
</script>
按下enter键虽然没有失去焦点,但也有可能会触发onchange事件 data:image/s3,"s3://crabby-images/f0435/f04355c41e79579881bafa73e96c432696836e75" alt="在这里插入图片描述"
如果开发希望将这两个事件同时绑定,又从功能上要求完全分开,就需要input输入框的值是否发生变化,如果没有发生变化,只会执行回车事件,如果发生了变化,则阻止回车事件,因为onChange会执行
<template>
<div class="hello">
<input type="text" @change="onchange" @keydown.enter="onEnter">
</div>
</template>
<script>
export default {
name: 'HelloWorld',
props: {
msg: String
},
data () {
return {
initValue: ''
}
},
methods: {
onEnter (e) {
const val = e.target.value
if (val === this.initValue) {
console.log('按下enter')
}
},
onchange (e) {
this.initValue = e.target.value
console.log('改变了')
}
}
}
</script>
输入后第一次按下回车,onenter虽然会触发,但我们的不想要执行的console.log并没有执行。 data:image/s3,"s3://crabby-images/1d8c7/1d8c777e342daebed501d04642986b4e9099b7b0" alt="在这里插入图片描述" 再次多次点击回车,不会再执行onchange,因为值没有变化 data:image/s3,"s3://crabby-images/ce0eb/ce0eb0ed45c3a815ca19654ff9f182c29573526e" alt="在这里插入图片描述"
再次说明,失去焦点后,会先判断onchange是否执行,再执行onblur
<template>
<div class="hello">
<input type="text" @change="onchange" @keydown.enter="onEnter" @blur="onblur">
</div>
</template>
<script>
export default {
name: 'HelloWorld',
props: {
msg: String
},
data () {
return {
initValue: ''
}
},
methods: {
onEnter (e) {
const val = e.target.value
if (val === this.initValue) {
console.log('按下enter')
}
},
onchange (e) {
this.initValue = e.target.value
console.log('改变了')
},
onblur () {
console.log('失去焦点了')
}
}
}
</script>
data:image/s3,"s3://crabby-images/fed8b/fed8b1383adf4b7345e96ecee67e993f4bde5e6c" alt="在这里插入图片描述"
onblur 失去焦点事件
当用户输入完成后,无论点击了其它地方,或者代码控制失去焦点,只要有聚焦到失去焦点这一变化,就一定会触发onblur,如果原本就是失去焦点状态,再次失去焦点,onblur事件不会再触发。
<template>
<div class="hello">
<input type="text" @change="onchange" @blur="onblur" ref="input1">
<button @click="clickBtn">失去焦点</button>
</div>
</template>
<script>
export default {
name: 'HelloWorld',
props: {
msg: String
},
data () {
return {
initValue: ''
}
},
methods: {
clickBtn (e) {
this.$refs.input1.blur()
this.$refs.input1.blur()
this.$refs.input1.blur()
},
onblur () {
console.log('失去焦点了')
}
}
}
</script>
无论怎么点击按钮都不会触发 data:image/s3,"s3://crabby-images/1c19d/1c19df3c0c6029d9edfd1e3ebc80e74b72f7a41e" alt="在这里插入图片描述"
<template>
<div class="hello">
<input type="text" @change="onchange" @blur="onblur" ref="input1">
<button @click="clickBtn">失去焦点</button>
</div>
</template>
<script>
export default {
name: 'HelloWorld',
props: {
msg: String
},
data () {
return {
initValue: ''
}
},
methods: {
clickBtn (e) {
this.$refs.input1.blur()
this.$refs.input1.blur()
this.$refs.input1.focus()
this.$refs.input1.blur()
},
onblur () {
console.log('失去焦点了')
}
}
}
</script>
点击一次按钮 data:image/s3,"s3://crabby-images/87c43/87c43a52c77883f4cd12e68a405652e74ff83a3b" alt="在这里插入图片描述"
但是,按下回车,并不会失去焦点,onblur不会触发
<template>
<div class="hello">
<input type="text" @change="onchange" @keydown.enter="onEnter" @blur="onblur">
</div>
</template>
<script>
export default {
name: 'HelloWorld',
props: {
msg: String
},
data () {
return {
initValue: ''
}
},
methods: {
onEnter (e) {
console.log('按下enter')
},
onblur () {
console.log('失去焦点了')
}
}
}
</script>
data:image/s3,"s3://crabby-images/15f46/15f46422bbe57427e3738aa5f587fbbab4c385ff" alt="在这里插入图片描述"
说明,vue的input输入框事件是从原生的input输入框封装而来的,所以对于原生html input输入框事件,与上述说明一致。
|