首頁 >web前端 >js教程 >Ajax開啟新視窗被瀏覽器攔截的兩種解決方法

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

亚连
亚连原創
2018-05-23 10:09:072239瀏覽

最近在做付款時發現打開支付視窗時被瀏覽器攔截了,怎麼回事呢?下面跟大家分享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校驗是否重複的實作程式碼

Ajax實作phpcms 讚功能(圖文教學)

ajax實作頁面載入和內容刪除

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

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