最近在做支付時發(fā)現(xiàn)打開支付窗口時被瀏覽器攔截了,百度了一下才發(fā)現(xiàn)是因為打開窗口前用ajax驗證是否能支付,所以不是用戶主動觸發(fā)的打開ixin窗口,瀏覽器認為這樣不安全,所以給攔截了。
解決辦法一
先開始打開一個空的新窗口,然后改變新窗口的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("正在加載請稍后!"); } });
這種實現(xiàn)方式有個弊端,就是不管ajax有沒有成功,都會執(zhí)行 var wd = window.open();這行代碼,所以成功和失敗都會打開一個新窗口,除非在失敗后進行關(guān)閉,但這樣用戶體驗會非常不好,所以我用的第二種方式去實現(xiàn)的。
解決辦法二
因為ajax是默認是異步的,這樣性能高,用戶體驗好,但這也導致了安全問題,要讓瀏覽器認為彈出新窗口是安全的,必須讓彈新窗口之前所有的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("正在加載請稍后!"); } });
相信看了本文案例你已經(jīng)掌握了方法,更多精彩請關(guān)注Gxl網(wǎng)其它相關(guān)文章!
推薦閱讀:
基于Ajax技術(shù)來實現(xiàn)無刷新用戶登錄(附代碼)
AJAX實現(xiàn)不刷新登錄
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com