最近在做付款時發現打開支付視窗時被瀏覽器攔截了,怎麼回事呢?下面跟大家分享Ajax開啟新視窗被瀏覽器攔截的兩種解決辦法,一起看看吧
最近在做支付時發現開啟支付視窗時被瀏覽器攔截了,百度了一下才發現是因為打開窗口前用ajax驗證是否能支付,所以不是用戶主動觸發的打開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("正在加载请稍后!"); } });
這種實作方式有個弊端,就是不管ajax有沒有成功,都會執行var wd = window.open();這行程式碼,所以成功和失敗都會打開一個新窗口,除非在失敗後進行關閉,但這樣用戶體驗會非常不好,所以我用的第二種方式去實現的。
解決方案二
因為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("正在加载请稍后!"); } });上面是我整理給大家的,希望未來對大家有幫助。 相關文章:
以上是Ajax開啟新視窗被瀏覽器攔截的兩種解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!