欢迎来到福编程网,本站提供各种互联网专业知识!

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

发布时间:2016-05-07 作者:Elong_Deo 来源:转载
这篇文章主要为大家详细介绍了ajax回调打开新窗体防止浏览器拦截的有效方法,感兴趣的朋友可以参考一下

ajax回调打开新窗体防止浏览器拦截,就这么做!

问题剖析:

代码
  1. function click_fun(){
  2. window.open("www.baidu.com");//能打开
  3. $.ajax({
  4. 'url': '${pageContext.request.contextPath}/activity/savePrizes.htm',
  5. 'type': 'post',
  6. 'dataType': 'json',
  7. 'data': data,
  8. success: function (data) {
  9. window.open("www.baidu.com");//被拦截
  10. },
  11. error:function(){
  12. }
  13. });
  14. }

分析:

打开新窗体只能在点击事件内触发,点击事件内的回调函数内打开窗体会被拦截,浏览器会认为是广告弹窗之类的代码

解决1:

代码
  1. function click_fun_new(){
  2. var tempwindow=window.open();//先打开临时窗体,由于是点击事件内触发,不会被拦截
  3. $.ajax({
  4. 'url': '${pageContext.request.contextPath}/activity/savePrizes.htm',
  5. 'type': 'post',
  6. 'dataType': 'json',
  7. 'data': data,
  8. success: function (data) {
  9. tempwindow.location = "www.baidu.com";//当回调的时候更改临时窗体的路径
  10. },
  11. error:function(){
  12. tempwindow.close();//回调发现无需打开窗体时可以关闭之前的临时窗体
  13. }
  14. });
  15. }

解决2:

代码
  1. function click_fun_new(){
  2. var flag = false;
  3. $.ajax({
  4. 'url': '${pageContext.request.contextPath}/activity/savePrizes.htm',
  5. 'type': 'post',
  6. 'dataType': 'json',
  7. 'data': data,
  8. 'async':false,//同步请求
  9. success: function (data) {
  10. $("#a").attr("href","www.baidu.com");//当回调的时候更改页面上或创建的某个a标签的href
  11. flag = true;//更改标志
  12. },
  13. error:function(){
  14. }
  15. });
  16. if(flag){
  17. $("#a").click();//href属性更改后模拟点击
  18. }
  19. }

以上就是ajax回调打开新窗体防止浏览器拦截的两种方法,希望对大家的学习有所帮助。

相关推荐