ajax请求里面调用window.open被拦截如何处理
程序员文章站
2022-04-10 11:04:14
...
这次给大家带来ajax请求里面调用window.open被拦截如何处理,处理ajax请求里面调用window.open被拦截的注意事项有哪些,下面就是实战案例,一起来看一下。
该方法优点描述:比如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(){} });
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
以上就是ajax请求里面调用window.open被拦截如何处理的详细内容,更多请关注其它相关文章!
推荐阅读
-
ajax请求成功后新开窗口window.open()被拦截解决方法
-
Ajax请求响应中用window.open打开新窗口被拦截的解决方法
-
ajax请求成功后新开窗口window.open()被拦截解决方法
-
Ajax打开新窗口被拦截时如何处理
-
Ajax请求响应中用window.open打开新窗口被拦截的解决方法
-
ajax请求成功后新开窗口window.open()被拦截解决方法
-
Ajax请求响应中用window.open打开新窗口被拦截的解决方法
-
Ajax请求响应中打开新窗口被拦截应该如何处理
-
Ajax打开新窗口被拦截时如何处理
-
ajax请求成功后新开窗口window.open()被拦截解决方法