小編給大家分享一下Ajax打開新窗口被瀏覽器攔截怎么辦,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
高坪網(wǎng)站制作公司哪家好,找成都創(chuàng)新互聯(lián)公司!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。成都創(chuàng)新互聯(lián)公司于2013年開始到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選成都創(chuàng)新互聯(lián)公司。
最近在做支付時(shí)發(fā)現(xiàn)打開支付窗口時(shí)被瀏覽器攔截了,百度了一下才發(fā)現(xiàn)是因?yàn)榇蜷_窗口前用ajax驗(yàn)證是否能支付,所以不是用戶主動(dòng)觸發(fā)的打開ixin窗口,瀏覽器認(rèn)為這樣不安全,所以給攔截了。
解決辦法一
先開始打開一個(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("正在加載請稍后!"); } });
這種實(shí)現(xiàn)方式有個(gè)弊端,就是不管ajax有沒有成功,都會(huì)執(zhí)行 var wd = window.open();這行代碼,所以成功和失敗都會(huì)打開一個(gè)新窗口,除非在失敗后進(jìn)行關(guān)閉,但這樣用戶體驗(yàn)會(huì)非常不好,所以我用的第二種方式去實(shí)現(xiàn)的。
解決辦法二
因?yàn)閍jax是默認(rèn)是異步的,這樣性能高,用戶體驗(yàn)好,但這也導(dǎo)致了安全問題,要讓瀏覽器認(rèn)為彈出新窗口是安全的,必須讓彈新窗口之前所有的ajax是同步的,具體代碼為
$.ajax({ type: "POST", dataType: "json", url: URL, async: false,//同步請求 data: {orderNo:orderNo}, success: function(data) { if(data.status=='success'){ window.open("www.baidu.com"); }else{ alert('訂單不能支付!'); } }, error: function(data) { alert("正在加載請稍后!"); } });
以上是“Ajax打開新窗口被瀏覽器攔截怎么辦”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!