window.open打开新窗口被浏览器拦截的处理方法

转自:https://www.cnblogs.com/digdeep/p/4590337.html?tvd

 

window.open是javascript函数,该函数的作用是打开一个新窗口或这改变原来的窗口,如果你直接在js中调用window.open()函数去打开一个新窗口,浏览器会拦截你,那么如何避免呢。

注意,只有直接使用js调用 window.open(url); 打开新窗口时,才会被拦截,如果是改变原理额窗口:window.open(url,'_self'); 则不会被拦截。

那么 js调用 window.open(url); 打开新窗口,如何才能不会浏览器拦截呢?

浏览器会拦截你,是认为你将弹出广告等用户不想得到的窗体,所以如果不想让浏览器拦截你,你可以将这个函数改为用户点击时触发,这样浏览器就认为是用户想访问这个页面,而不是你直接弹出给用户。

0)最好的解决方法:

var form = document.createElement('form');
form.action = 'www.baidu.com?id=1';
form.target = '_blank';

form.method = 'POST';

document.body.appendChild(form);
form.submit();

这种方式,如果需要传递参数时,需要使用 POST 方法, 默认的get方法, 无法传递参数。也就是新页面的url中没有参数部分。

另外,Ajax下载文件时也是用form 表单来模拟下载。


1)所以常用的方法就是在超链接里加入onclick事件,如<a href="javascript:void(0)" onclick="window.open()"></a>这样用户点击这个超链接,浏览器会认为它是打开一个新的链接,所以就不会拦 截。

2)还有一种方法:

      setTimeout('window.open(url);', 500);

使用 setTimeout 包装一下,也可以防止被浏览器拦截。注意这里的超时时间不能太短,否则也会被拦截。

3)可是有时候我们会遇到想要弹出一个窗口,可是却是在onckick事件执行后,才去弹出来的,这时就会被浏览器拦截,我们可以通过下面的方法来避免,就是 先用window.open打开一个窗口,然后修改地址。如

var tempwindow=window.open('_blank');打开一个窗口,然后用

tempwindow.location='http://www.baidu.com';使这个窗口跳转到百度,这样就会呈现弹出百度窗口的效果了。

转载于:https://www.cnblogs.com/yang-C-J/p/7942986.html

### 解决 JavaScript `window.open` 被浏览器拦截的问题 现代浏览器出于安全性和用户体验的考虑,默认启用了弹出窗口拦截器。当 `window.open` 方法被调用时,如果不符合浏览器的安全策略(例如非用户交互触发),则可能会被拦截。以下是一些有效的解决方法和注意事项: #### 1. 绑定到用户交互事件 确保 `window.open` 的调用是在直接响应用户交互(如点击按钮或链接)的事件处理函数中执行。这是最推荐的解决方法,因为它符合浏览器的安全策略,并提供最佳的用户体验。 ```html <button onclick="openPopup()">打开弹出窗口</button> <script> function openPopup() { window.open('https://www.example.com', '_blank'); } </script> ``` 这种方法利用了用户交互事件来触发弹窗,避免了被浏览器拦截的可能性[^2]。 #### 2. 检查并调整浏览器设置 指导用户检查他们的浏览器设置和扩展程序,并根据需要添加例外或禁用拦截器。然而,这不应作为主要的解决方案,因为它依赖于用户的操作,且可能无法覆盖所有用户群体。 #### 3. 使用模态对话框替代弹出窗口 如果弹出窗口的内容相对简单,可以考虑使用模态对话框代替弹出窗口。模态对话框不会被浏览器拦截,并且可以提供更好的用户体验。以下是使用 Bootstrap Modal 的示例: ```html <!-- Button trigger modal --> <button type="button" class="btn btn-primary" data-bs-toggle="modal" data-bs-target="#exampleModal"> 打开模态窗口 </button> <!-- Modal --> <div class="modal fade" id="exampleModal" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true"> <div class="modal-dialog"> <div class="modal-content"> <div class="modal-header"> <h5 class="modal-title" id="exampleModalLabel">模态标题</h5> <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button> </div> <div class="modal-body"> 这是模态窗口的内容。 </div> <div class="modal-footer"> <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">关闭</button> </div> </div> </div> </div> ``` 通过这种方式,可以避免弹出窗口被拦截的问题,同时提升用户体验[^2]。 #### 4. 异步操作与用户确认 如果必须在非用户交互的情况下打开弹出窗口(例如,在异步操作完成后),请先向用户显示一个消息或进度指示器,然后在用户确认后再打开弹出窗口。例如: ```javascript // 异步操作完成后提示用户 alert("操作已完成,请点击确定以继续。"); window.open('https://www.example.com', '_blank'); ``` 这种方法可以减少意外弹出窗口的发生,从而提高用户体验。 #### 5. 提交表单实现跳转 在某些情况下,可以通过提交表单的方式实现页面跳转,而不是依赖 `window.open`。以下是一个基于表单提交的示例: ```html <form action="https://www.example.com" method="get" id="test_form"> </form> <script> document.getElementById('test_form').submit(); </script> ``` 这种方法绕过了弹出窗口拦截器,适用于需要自动跳转的场景[^5]。 #### 6. 注意事项 - 避免在页面加载、定时器回调或其他非用户交互事件中调用 `window.open`,因为这些情况下的弹窗很可能会被拦截。 - 如果使用 Vue 或其他框架,确保 `window.open` 的调用是在用户交互事件中进行的。例如: ```javascript methods: { openWindow() { window.open('https://www.example.com', '_blank'); } } ``` 然后绑定到按钮点击事件: ```html <button @click="openWindow">打开新窗口</button> ``` 这种做法可以有效避免弹窗被拦截的问题[^3]。 --- ### 总结 通过理解浏览器拦截弹出窗口的原因,并采取相应的解决方法,可以确保网页功能正常运行,并提供良好的用户体验。优先考虑用户交互触发的弹出窗口,并尽可能使用替代方案(如模态对话框),可以最大限度地减少弹出窗口被拦截的可能性。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值