ajax请求里面调用window.open会被浏览器拦截(优化版)
发布时间:2020-12-16 03:10:54 所属栏目:百科 来源:网络整理
导读:众所周知,ajax请求里面调用window.open会被浏览器拦截方法有两种解决办法,但是经测验例如ajax改为async:false同步请求还会出现一些问题(比如站点外网址被拦截); 第一种解决办法优化: 该方法优点描述:比如ajax回调函数失败,浏览器默认打开的空链接会
众所周知,ajax请求里面调用window.open会被浏览器拦截方法有两种解决办法,但是经测验例如ajax改为async:false同步请求还会出现一些问题(比如站点外网址被拦截);
该方法优点描述:比如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',async:false,//改为同步请求 data:parameter,success:function(data) { if(data.TSR_CODE == "0"){ window.open(xxx); }else{ alert(data.TSR_MSG); } },complete:function(){} }); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |