问题:

前面开发项目时碰到一个问题,ajax 异步请求成功后需要新开窗口打开 url,使用的是 window.open() 方法,但是很可惜被浏览器给拦截了,怎么解决这个问题呢?

分析:

浏览器之所以拦截新开窗口是因为该操作并不是用户主动触发的,所以它认为这是不安全的就拦截了(不过如果是 _self 的话就不会有这个限制),即使 ajax 回调函数中模拟执行 click 或者 submit 等用户行为(trigger('click')),浏览器也会认为不是由用户主动触发的,因此不能被安全执行,所以被拦截。

解决方法:

1、异步改为同步,即:async:false

2、将新开窗口指向为一个对象,然后修改对象的 url,比如:

$('.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 请求,至少博主测试了下仍然被浏览器所拦截。

参考资料:弹窗解决最终奥义,人类再再也无法阻止弹窗了!

最新文章

  1. JDBC、JTA、Spring的事务管理
  2. 四则运算GUI设计2.0
  3. asynchronous vs non-blocking
  4. C#MD5为密码加密
  5. Linux防火墙基本知识
  6. CSS 居中方法集锦(*******************************)
  7. 【HDOJ】1073 Online Judge
  8. web开发工具IDE
  9. Redis实战之Redis + Jedis[转]
  10. spring源码分析构建
  11. VS2013中C++创建DLL导出class类
  12. 《Java从入门到放弃》入门篇:springMVC数据传递
  13. 201521123055 《Java程序设计》第7周学习总结
  14. TypeScript装饰器(decorators)
  15. mysql \N 的疑惑
  16. python 操作Excel文件
  17. SVN状态说明
  18. 安装Scala开发环境
  19. Servlet处理GET和POST请求
  20. Centos7 Install Kubernetes

热门文章

  1. MySQL自成一派的查询提示
  2. 硬盘内部硬件结构和工作原理详解[zz]
  3. [svc]centos7的服务治理-systemd
  4. HTML5学习笔记(二十六):JavaScript的错误处理
  5. How do I measure JVM startup time?
  6. 每日英语:The Most Destructive, Unpredictable Force in Tech
  7. Android环境搭建问题的解决: Connection to http://dl-ssl.google.com refused
  8. 【ARM】ARM体系结构-GPIO
  9. android 模拟器 sdcard权限修改
  10. 【转】Python 字典中的中文输出问题