实现页面跳转后,原页面弹窗且不让后页面失去焦点-javascript函数执行顺序问题

最近心不静,碰到问题太没耐心,弄了好久。

首先先看看这个脚本,需要说的是,这个脚本在IE、火狐上执行顺序是没有问题,但在谷歌、360等浏览器上就不能按顺序走;在没做定时器前,页面无法跳转;做了定时后,页面跳转后,定时的弹窗让跳转页面失去焦点。

<script type="text/javascript" language="javascript">
	//form1, form表单的id
	function alisubmit(){
		document.form1.submit();
		window.setTimeout("checkreturn()",1000); 
	}
</script>
<script type="text/javascript" language="javascript">
	var checkreturn = function(){
		var flag=false;
		if(confirm("请确认是否已经支付,如已完成支付,可点击'确认',进入下一步。")){
			flag=true;
		}
		$.ajax({
                url : "checkPayResult.action",  
                data : {'user.outtradeno' : '<%=out_trade_no %>'}, 
                type : "POST",
                dataType : "text",
                success : function(data) {
                    if (data != null && data == "true") {  
                    	window.parent.open('<%=basePath%>pages/ok.jsp', '_self');
                        return true;
                    } else{
                    	if(flag){
                    		window.parent.open('<%=basePath%>pages/failed.jsp', '_self');
                    	}
                        return false;
                    }
                }  
            }); 
	};
</script>

后来分析知道,javascript分预编译和执行两步的,弹窗的checkreturn函数在预编译就需要获得处理,导致表单的提交放在了最后,这和我们要的后果不符。花了好长时间解决这个bug,但因为时间,我还是选择了另一种实现方案,就是用div弹窗代替原来的效果,找的demo如下图,你可以在资源里下载。



  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值