這次帶給大家Ajax打開新視窗被攔截時如何處理,處理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("正在加载请稍后!"); } });
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
推薦閱讀:
以上是Ajax開啟新視窗被攔截時如何處理的詳細內容。更多資訊請關注PHP中文網其他相關文章!