java监听焦点事件_监听input输入框的失去焦点事件与按钮点击事件执行的顺序问题...

1.问题描述

当在监听input失去焦点的事件的时候,在input输入框输入一段文字之后,点击发送按钮会发现,只触发了失去焦点事件,按钮点击事件并没有被触发,当再次点击按钮的时候,事件才会被触发

2.代码

发送

$(function(){

$(".inTest").focus(function(){

}).blur(function(){

alert("-----blur----");

});

$(".btn-send").click(function(e){

alert("-----click----");

});

});

3.效果图

090860f4e93a2dad28b9a152c5c01881.png

4.解决办法

由于失去焦点事件发生的顺序在点击事件之前,这样我预期的触发点击事件的效果就达不到,为了达到触发点击事件,我在失去焦点时间里面加了setTimeout()方法,让失去焦点事件延迟500毫秒再触发,这样就调换了失去焦点和按钮点击事件的顺序,做到我所期待的效果

5.解决之后的代码

发送

$(function(){

$(".inTest").focus(function(){

}).blur(function(){

setTimeout(function(){//添加时间定时器

alert("-----blur----");

},500);

});

$(".btn-send").click(function(e){

alert("-----click----");

});

});

6.解决之后的效果图

99ae7b46a990362cf19ce7a645796f5d.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值