首頁 >後端開發 >php教程 >兩種Ajax開啟新視窗被瀏覽器攔截解決方法

兩種Ajax開啟新視窗被瀏覽器攔截解決方法

小云云
小云云原創
2018-01-08 13:46:541631瀏覽

本文主要和大家分享,最近在做支付時發現打開支付窗口時被瀏覽器攔截了,百度了一下才發現是因為打開窗口前用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回呼開啟新視窗防止瀏覽器攔截有效方法

iframe 跨站被瀏覽器攔截

#JS判斷網頁廣告是否被瀏覽器攔截過濾的程式碼_javascript技巧

以上是兩種Ajax開啟新視窗被瀏覽器攔截解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn