为了账号安全,请及时绑定邮箱和手机立即绑定

onblur 与 onclick冲突怎么解决

onblur 与 onclick冲突怎么解决

动漫人物 2019-04-21 20:14:39
有四个可折叠的组件,里面有teaxarea和buttonhttps://jsfiddle.net/tt0vvdyt/input区域onblur的时候会自动调ajaxsave数据点击savebutton也会调ajaxsave数据。并且弹出对话框提示保存成功并合起折叠控件问题:如何在点击buttonsave的时候和onblur的save不重复调用。方案:我把button的save给做成假的解决了这个问题。就出现了button在刚打开折叠时点击button空点击。不能接受我又做了打开折叠的时候自动focustextarea。解决了以上问题。由此又衍生了第三个问题。当focus在第一个折叠区域的textarea时点击展开第二个折叠区域会保存两次。因为当第一次折叠调用onblur保存后,进入onclick第二个展开并focus第二个textarea时ajax恰好返回弹出保存成功对话框导致textarea瞬间失去焦点。再次调用刚刚展开的textarea的onblur保存。最后并自动折叠第二个折叠控件。做到这,我已经无计可施,如何才能让不调用第二次。怎么解?
查看完整描述

2 回答

?
九州编程

TA贡献1785条经验 获得超4个赞

在onblur里面setTimeou后再发起请求,在onclick里面先clearTimeout。这样你click引起的blur永远不会触发请求。
vartid;
onBlur=function(){
tid=setTimeout(function(){
//doblursave
},25);
};
onClick=function(){
clearTimeout(tid);
//doclicksave
}
                            
查看完整回答
反对 回复 2019-04-21
?
翻翻过去那场雪

TA贡献2065条经验 获得超14个赞

做个全局变量,初始时设为false,如果save了,则改变成true,然后在save里判断,如果该变量取值为false,则保存,否则不保存。
                            
查看完整回答
反对 回复 2019-04-21
  • 2 回答
  • 0 关注
  • 424 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信