ajax請求成功后新開窗口window.open()被攔截解決方法


ajax 異步請求成功后需要新開窗口打開 url,使用的是 window.open() 方法,但是很可惜被瀏覽器給攔截了,怎么解決這個問題呢
 

問題:

前面開發項目時碰到一個問題,ajax 異步請求成功后需要新開窗口打開 url,使用的是 window.open() 方法,但是很可惜被瀏覽器給攔截了,怎么解決這個問題呢?
分析:

瀏覽器之所以攔截新開窗口是因為該操作並不是用戶主動觸發的,所以它認為這是不安全的就攔截了(不過如果是 _self 的話就不會有這個限制),即使 ajax 回調函數中模擬執行 click 或者 submit 等用戶行為(trigger('click')),瀏覽器也會認為不是由用戶主動觸發的,因此不能被安全執行,所以被攔截。
解決方法:

1、異步改為同步,即:async:false

2、將新開窗口指向為一個對象,然后修改對象的 url,比如:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
$( '.task' ).bind( 'click' , function (){
var w = window.open();
$.ajax({
type: 'POST' ,
url: '/surveyTask' ,
dataType: 'json' ,
error: function (){
w.close();
},
success: function (res){
w.location = res.url;
}
});
});

最后需要說明的是:網上的動態添加 form 新開窗口的方法,並不適合 ajax 請求,至少博主測試了下仍然被瀏覽器所攔截。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM