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

 更新时间:2016年08月04日 11:38:07   作者:Ruthless  
这篇文章主要介绍了Ajax请求成功后打开新窗口地址的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下

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

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配合Spring实现文件上传功能代码

    Ajax配合Spring实现文件上传功能代码

    最近在开发一个可以上传图片到服务器的web表面页面,下面给大家分享需求和实现思路,需要的的朋友参考下吧
    2017-05-05
  • 什么是Ajax

    什么是Ajax

    ajax不是一种语言,而是多种技术组合在一起使用,ajax只是这几种技术组合的代名词
    2010-10-10
  • 基于AJAX的分页类实现代码

    基于AJAX的分页类实现代码

    随着AJAX在互联网上的广泛运用,公司也在越来越多的项目里涉及到了AJAX,最近一段时间空闲,于是就用JS写了一个基于AJAX的异步分页类。先不多说,还是先将源码贴出,再进行说明~~~
    2009-09-09
  • 使用jquery 的ajax调用总是错误亲测的解决方法

    使用jquery 的ajax调用总是错误亲测的解决方法

    使用jquery 的ajax功能调用一个页面,却发现总是出现错误,经过这么多测试终于正常了,尤其是 dataType: 'json',看来jquery有很严格的验证机制
    2013-07-07
  • ajax传递多个参数具体实现

    ajax传递多个参数具体实现

    在使用ajax过程中,传递参数是在所难免的尤其在特殊情况下传递多个参数,下面与大家分享下具体的是实现方法,感兴趣的朋友可以参考下哈
    2013-05-05
  • ajax回调打开新窗体防止浏览器拦截有效方法

    ajax回调打开新窗体防止浏览器拦截有效方法

    这篇文章主要为大家详细介绍了ajax回调打开新窗体防止浏览器拦截的有效方法,感兴趣的朋友可以参考一下
    2016-05-05
  • Ajax动态加载数据库示例

    Ajax动态加载数据库示例

    这篇文章主要介绍的是一个Ajax动态加载数据库示例,需要的朋友可以参考下
    2014-05-05
  • ajax调用简单实例

    ajax调用简单实例

    这篇文章主要介绍了ajax调用简单实例,结合实例形式分析了基于ajax调用讲URL返回数据填充到指定div的功能,需要的朋友可以参考下
    2015-12-12
  • Ajax添加数据与删除篇实现代码

    Ajax添加数据与删除篇实现代码

    Hello 大家好!这个ajax系列教程讲到这里已经完成50%了.第4篇讲了ajax向数据库添加数据,第5篇讲了ajax修改数据库中的数据.今天我们来讲ajax添加数据与删除并存的实例效果.
    2010-10-10
  • 简单实现Ajax无刷新分页效果

    简单实现Ajax无刷新分页效果

    这篇文章主要为大家详细介绍了简单实现Ajax无刷新分页效果的代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05

最新评论