ajax请求响应中window.open拦截解决

本文探讨了在Ajax回调函数中尝试改变窗口位置或打开新窗口时遇到的安全拦截问题,并提供了解决方案,包括使用临时窗口、同步执行、设置超时等方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题原因:

ajax回调函数中执行window.open或者模拟click事件,由于跳转操作不是用户主动触发,会被认为不安全,浏览器会进行拦截。
1: 在fun方法中调用window.open是不会被拦截的。
2:如果不是打开新窗口,而是改原来的网页地址,可以使用window.location = newurl 来实现,这样不会被拦截。

具体解决:

function  fun(){
     var tmpWin  = window.open()
      ajax(xxx, handle(){ 
            //回调函数
            var  newurl  = xxxx
            tmpWin.location.href = newurl;
       })
}

上面方法,存在一个问题时,因为先打开了空白窗口,如果ajax请求失败(网络或业务逻辑问题)后, 新窗口中就不会有正常的结果体现,有可能造成用户疑惑。
一个解决办法是,当ajax出现问题时,可以考虑给出一个提示,如 tmpWin.document.write(“服务器处理异常”);

甚至为了防止ajax响应时间过长,当窗口新建后,立即给出提示 tmpWin.document.write(“服务器正在处理中,请稍后”);

后面如果ajax正常返回,则因为设置了location值,原来打印的信息会被新的页面信息覆盖。

其他:ajax改为同步执行,用户等待时间较长,体验不好。而且服务器不能很快返回结果时仍会被拦截。

另: url参数都是字符串 需利用JSON.parse/stringify/ encodeURIComponent/decodeURIComponent进行转换
GET请求会刷新页面
POST请求模拟form表单提交

if(JumpData.method=='POST'){
    postcall(JumpData.url,JumpData.parameter);
     actionFun = function(){
       //POST请求 param参数遍历为form表单的input进行submit
       tempform.submit();
     }
 }else if(JumpData.method=='GET'){
     //GET请求请求参数在url内
     actionFun = function(){
         window.location.replace(JumpData.url)
     }
 }
 function postcall(url,params){
   tempform = document.createElement("form");
    tempform.action = url;
    tempform.method = "post";
    tempform.style.display="none";
    for (var x in params) {
        var opt = document.createElement("input");
        opt.name = x;
        opt.setAttribute("value",params[x]);
        tempform.appendChild(opt);
    }

    var opt = document.createElement("input");
    opt.type = "submit";
    opt.name = "postsubmit";
    tempform.appendChild(opt);
    document.body.appendChild(tempform);

}

setTimeout(function(){
   actionFun && actionFun();
},JumpData.second);
在开发过程中,遇到Ajax请求成功后使用window.open打开新窗口浏览器拦截的情况是很常见的。为了解决这一问题,建议深入阅读《解决Ajax响应window.open拦截的问题》这篇文章,它将为你提供多种解决方案,并帮助你更好地理解问题背后的原因。 参考资源链接:[解决Ajax响应window.open拦截的问题](https://wenku.csdn.net/doc/6412b5e4be7fbd1778d44c5f?spm=1055.2569.3001.10343) 首先,我们需要了解浏览器拦截window.open的机制。现代浏览器会基于用户交互的上下文来判断是否拦截新开窗口,因为它们认为这是为了防止恶意软件自动打开新窗口。因此,我们可以采取以下几种策略: 1. **在用户触发的事件中提前打开窗口**:在用户交互(如点击事件)中预开一个空白窗口,并在Ajax请求成功后,通过回调函数将该窗口的location属性指向新的URL。这种方法的代码示例如下: ```javascript function openWindow() { var newWindow = window.open('', '_blank'); makeAjaxRequest(function(url) { newWindow.location.href = url; }); } function makeAjaxRequest(callback) { // 假设的Ajax请求实现 var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) { callback(xhr.responseText); } }; xhr.open('GET', 'your-endpoint', true); xhr.send(); } ``` 注意,在实际应用中,需要处理Ajax请求失败的情况,避免新窗口为空白。 2. **使用同步Ajax请求**:虽然这种方法会影响用户体验,但在某些特定场景下可以作为一种备选方案。你可以将XMLHttpRequest的async属性设置为false,使得Ajax请求同步执行。 3. **改变设计策略**:考虑到用户体验和现代Web设计的趋势,改变设计策略避免使用新窗口是一种更为推荐的方法。比如,在当前页面内通过弹出模态框展示新内容,或在页面内进行内容更新。 总之,解决Ajax请求window.open浏览器拦截的问题需要综合考虑用户体验和浏览器安全策略。《解决Ajax响应window.open拦截的问题》为你提供了全面的解决方案,建议在解决当前问题后,继续深入学习相关的技术细节,以获得更全面的知识。 参考资源链接:[解决Ajax响应window.open拦截的问题](https://wenku.csdn.net/doc/6412b5e4be7fbd1778d44c5f?spm=1055.2569.3001.10343)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值