

该方法优点描述:比如ajax回调函数失败,浏览器默认打开的空链接会自动关闭,用户体验比较好。
var newwin;
$("#btn").click(function(){
newwim = window.open();
//此处调用ajax,异步即可:
$.ajax({
type:'POST',
url: ajaxurl,
dataType : 'json',
data:parameter,
beforeSend : function(){},
success:function(data) {
if(data.TSR_CODE == "0"){
newwin.location.href = xxx;//xxx为后端返回的地址;
}else{
alert(data.TSR_MSG);
newwin.close();//此处为ajax失败方法,自动关闭刚才会打开的页面;
}
},
error:function(){
console.log("访问出错,请重试!");
},
complete:function(){}
});
});第二种解决办法分析:
此方法测试过:比如后台返回的是站址,谷歌浏览器、360浏览器等等会拦截请求,火狐、qq浏览器不会拦截,预测是浏览器自身对站址这种类型做了拦截,普通的网址不被拦截;
$("#btn").click(function(){
//此处调用ajax,异步即可:
$.ajax({
type:'POST',
url: ajaxurl,
dataType : 'json',
async:false,//改为同步请求
data:parameter,
beforeSend : function(){},
success:function(data) {
if(data.TSR_CODE == "0"){
window.open(xxx);
}else{
alert(data.TSR_MSG);
}
},
error:function(){
console.log("访问出错,请重试!");
},
complete:function(){}
});相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!
推荐阅读:
JS中的JSON和Math使用案例分析
PromiseA+的实现步骤详解
