ajax打开新窗口被浏览器拦截的解决办法
生活随笔
收集整理的這篇文章主要介紹了
ajax打开新窗口被浏览器拦截的解决办法
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
最近在做支付時(shí)發(fā)現(xiàn)打開(kāi)支付窗口時(shí)被瀏覽器攔截了,百度了一下才發(fā)現(xiàn)是因?yàn)榇蜷_(kāi)窗口前用ajax驗(yàn)證是否能支付,所以不是用戶主動(dòng)觸發(fā)的打開(kāi)ixin窗口,瀏覽器認(rèn)為這樣不安全,所以給攔截了。
解決辦法一
先開(kāi)始打開(kāi)一個(gè)空的新窗口,然后改變新窗口的url,具體代碼為
var wd = window.open(); $.ajax({type: "POST",dataType: "json",url: URL,data: {orderNo:orderNo},success: function(data) {if(data.status=='success'){wd.location.href = 'http://www.baidu.com';}else{ alert('訂單不能支付!'); }},error: function(data) {alert("正在加載請(qǐng)稍后!");} });這種實(shí)現(xiàn)方式有個(gè)弊端,就是不管ajax有沒(méi)有成功,都會(huì)執(zhí)行 var wd = window.open();這行代碼,所以成功和失敗都會(huì)打開(kāi)一個(gè)新窗口,除非在失敗后進(jìn)行關(guān)閉,但這樣用戶體驗(yàn)會(huì)非常不好,所以我用的第二種方式去實(shí)現(xiàn)的。
解決辦法二
因?yàn)閍jax是默認(rèn)是異步的,這樣性能高,用戶體驗(yàn)好,但這也導(dǎo)致了安全問(wèn)題,要讓瀏覽器認(rèn)為彈出新窗口是安全的,必須讓彈新窗口之前所有的ajax是同步的,具體代碼為
$.ajax({type: "POST",dataType: "json",url: URL,async: false,//同步請(qǐng)求data: {orderNo:orderNo},success: function(data) {if(data.status=='success'){window.open("www.baidu.com");}else{alert('訂單不能支付!');}},error: function(data) {alert("正在加載請(qǐng)稍后!");} });總結(jié)
以上是生活随笔為你收集整理的ajax打开新窗口被浏览器拦截的解决办法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 网络-数据链路层回顾
- 下一篇: HTML5自动换行的间距设置,div c