主页 > 知识库 > Ajax请求成功后打开新窗口地址

Ajax请求成功后打开新窗口地址

热门标签:ai机器人电销资源 机器人电销骗局揭秘 个人怎样在百度地图标注地名 腾讯地图标注位置能用多久 硅语电话机器人公司 越南河内地图标注 超级大富翁地图标注 云呼外拨网络电话系统 地图标注项目怎么样

废话不多说,关键代码如下所示:

jQuery.ajax({
"type":"post",
"url":"http://www.baidu.com", 
"success":function(rel){
if(rel.isSuccess){ 
window.open(rel.url,"_blank");
}
}
}); 

这个url请求成功后window.open(rel.url,"_blank");会被浏览器拦截,无法打开新窗口,如果把window.open()放在ajax外面,问题就迎刃而解,代码如下:

var result="";
jQuery.ajax({
"type":"post",
"url":"http://www.baidu.com", 
"success":function(rel){
if(rel.isSuccess){ 
result=rel.url;
//window.open(rel.url,"_blank");
}
}
});
if(result.length>0){
window.open(result,"_blank");
}

下面看下在Ajax响应之后打开新窗口

最近的开发中有一个功能,点击一个链接之后,要判断当前的用户是否登录,没有登录的话,需要弹出一个登录对话框,用户登录之后,再在新的窗口(标签)中打开链接指向的Url。

不多说,直接贴出代码:

$(document).delegate("a", "click", function () { 
var actionUrl = $(this).attr("href"); 
var ssoAction = function () { window.open(actionUrl, '_blank'); }; 
if (isLogin()) { 
ssoAction(); 
} else { 
popup.show({login:function () { 
$.ajax({ 
type: "post", 
dataType: "json", 
url: "/Account/Login", 
data: $("frmLogin").serialize(), 
//发送方式改为同步,避免弹出页面被浏览器拦截
async: false, 
success: function (oData) { 
ssoAction(); 
} 
}); 
}); 
} 
return false; 
});

重点:需要使用同步提交,使用异步提交,callback里面打开新窗口(标签),会被浏览器认为是恶意行为。

您可能感兴趣的文章:
  • Ajax请求响应中用window.open打开新窗口被拦截的解决方法
  • ajax怎么打开新窗口具体如何实现
  • Ajax打开新窗口被浏览器拦截的两种解决办法

标签:郑州 洛阳 林芝 邢台 内蒙古 舟山 辽源 海南

巨人网络通讯声明:本文标题《Ajax请求成功后打开新窗口地址》,本文关键词  Ajax,请求,成功,后,打开,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《Ajax请求成功后打开新窗口地址》相关的同类信息!
  • 本页收集关于Ajax请求成功后打开新窗口地址的相关信息资讯供网民参考!
  • 推荐文章