最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Ajax打开新窗口被拦截时如何处理

来源:懂视网 责编:小采 时间:2020-11-27 19:56:52
文档

Ajax打开新窗口被拦截时如何处理

Ajax打开新窗口被拦截时如何处理:这次给大家带来Ajax打开新窗口被拦截时如何处理,处理Ajax打开新窗口被拦截的注意事项有哪些,下面就是实战案例,一起来看一下。最近在做支付时发现打开支付窗口时被浏览器拦截了,百度了一下才发现是因为打开窗口前用ajax验证是否能支付,所以不是用户主动触
推荐度:
导读Ajax打开新窗口被拦截时如何处理:这次给大家带来Ajax打开新窗口被拦截时如何处理,处理Ajax打开新窗口被拦截的注意事项有哪些,下面就是实战案例,一起来看一下。最近在做支付时发现打开支付窗口时被浏览器拦截了,百度了一下才发现是因为打开窗口前用ajax验证是否能支付,所以不是用户主动触

这次给大家带来Ajax打开新窗口被拦截时如何处理,处理Ajax打开新窗口被拦截的注意事项有哪些,下面就是实战案例,一起来看一下。

最近在做支付时发现打开支付窗口时被浏览器拦截了,百度了一下才发现是因为打开窗口前用ajax验证是否能支付,所以不是用户主动触发的打开ixin窗口,浏览器认为这样不安全,所以给拦截了。

解决办法一

先开始打开一个空的新窗口,然后改变新窗口的url,具体代码为

var wd = window.open();
$.ajax({
 type: "POST",
 dataType: "json",
 url: URL,
 data: {orderNo:orderNo},
 success: function(data) {
 if(data.status=='success'){
 wd.location.href = 'http://www.baidu.com';
 }else{ 
 alert('订单不能支付!'); 
 }
 },error: function(data) {
 alert("正在加载请稍后!");
 }
});

这种实现方式有个弊端,就是不管ajax有没有成功,都会执行 var wd = window.open();这行代码,所以成功和失败都会打开一个新窗口,除非在失败后进行关闭,但这样用户体验会非常不好,所以我用的第二种方式去实现的。

解决办法二

因为ajax是默认是异步的,这样性能高,用户体验好,但这也导致了安全问题,要让浏览器认为弹出新窗口是安全的,必须让弹新窗口之前所有的ajax是同步的,具体代码为

$.ajax({
 type: "POST",
 dataType: "json",
 url: URL,
 async: false,//同步请求
 data: {orderNo:orderNo},
 success: function(data) {
 if(data.status=='success'){
 window.open("www.baidu.com");
 }else{
 alert('订单不能支付!');
 }
 },
 error: function(data) {
 alert("正在加载请稍后!");
 }
});

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

基于Ajax技术来实现无刷新用户登录(附代码)

AJAX实现不刷新登录

文档

Ajax打开新窗口被拦截时如何处理

Ajax打开新窗口被拦截时如何处理:这次给大家带来Ajax打开新窗口被拦截时如何处理,处理Ajax打开新窗口被拦截的注意事项有哪些,下面就是实战案例,一起来看一下。最近在做支付时发现打开支付窗口时被浏览器拦截了,百度了一下才发现是因为打开窗口前用ajax验证是否能支付,所以不是用户主动触
推荐度:
标签: 拦截 解决 窗口
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top