input 的blur事件之后button的onclick事件不执行解决方案

最近发现网页程序中有个BUG,就是在input标签输入框中输入完数据后,直接点击“取消” 按钮的时候、出现网页崩死的情况;

 

经过小主酸菜我,各种方法的尝试后,找到一个初步可以解决的方案,在这里分享给大家:

 

首先,分析一下原因:input标签直接离开后,触发的事件是input标签的blur事件;然后直接去点击了取消按钮,执行button事件。

 

由于js是单线程的所以就出现了问题,现在需要让blur先执行验证,然后在触发click事件。

 

所以:咱们的解决方案就是,要让他blur事件先验证了,然后再执行button的onclick事件,让js一步一步的来;

给button的onclick事件写一个推迟执行的方法、利用setTimeout();

 

实例代码如下:

 

 

<!--<input type="reset" οnclick="BackToMainPage()" value="取消" class="reset tf" id="btnCancel" />   这是原来的取消按钮的代码,下图为改善后。-->
                        

<input type="reset" value="取消" class="reset tf" id="btnCancel" />

 

 $("#btnCancel").mousedown(
        function (e) {
            setTimeout('BackToMainPage()', 100);
        });

 

 

 

 

写的不太好,如有其它问题,请指教。

 

转载于:https://www.cnblogs.com/sauerkraut/p/5013231.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值