DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> AJAX入門 >> AJAX基礎知識 >> Ajax打開新窗口被浏覽器攔截的兩種解決辦法
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("正在加載請稍後!");
  }
});

以上所述是小編給大家介紹的Ajax打開新窗口被浏覽器攔截的兩種解決辦法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved