js实现window.open不被拦截的解决方法汇总
本文实例讲述了js实现window.open不被拦截的解决方法。分享给大家供大家参考。具体分析如下:
一、问题:
今天在处理页面ajax请求过程中,想实现请求后打开新页面,就想到通过 js window.open 来实现,但是最终都被浏览器拦截了。
二、分析:
在谷歌搜索有没有解决方法,有些说可以通过新建a标签,模拟点击来实现,但是测试发现都实现不了,照样被浏览器拦截。
最后找到了一个折中的办法,可以实现新页面打开,但是没有a标签的那种直接流量新页面的效果。
三、实现代码:
var newTab=window.open('about:blank');
$.ajax({
success:function(data){
if(data){
//window.open('https://www.jb51.net');
newTab.location.href="https://www.jb51.net";
}
}
})
})
其它方法:
<!--
$(
function()
{
//方法一
window.showModalDialog("https://www.jb51.net/");
window.showModalDialog("https://www.jb51.net/");
//方法二
var aa=window.open();
setTimeout(function(){
aa.location="https://www.jb51.net";
}, 100);
var b=window.open();
setTimeout(function(){
b.location="https://www.jb51.net";
}, 200);
var c=window.open();
setTimeout(function(){
c.location="https://www.jb51.net";
}, 300);
var d=window.open();
setTimeout(function(){
d.location="https://www.jb51.net";
}, 400);
var ee=window.open();
setTimeout(function(){
ee.location="https://www.jb51.net";
}, 500);
var f=window.open();
setTimeout(function(){
f.location="https://www.jb51.net";
}, 600);
var g=window.open();
setTimeout(function(){
g.location="https://www.jb51.net";
}, 700);
var h=window.open();
setTimeout(function(){
h.location="https://www.jb51.net";
}, 800);
var i=window.open();
setTimeout(function(){
i.location="https://www.jb51.net";
}, 900);
var j=window.open();
setTimeout(function(){
j.location="https://www.jb51.net";
}, 1000);
//方法三
var a = $("<a href='https://www.jb51.net' target='_blank'>Apple</a>").get(0);
var e = document.createEvent('MouseEvents');
e.initEvent( 'click', true, true );
a.dispatchEvent(e);
var a = $("<a href='https://www.jb51.net' target='_blank'>Apple</a>").get(0);
var e = document.createEvent('MouseEvents');
e.initEvent( 'click', true, true );
a.dispatchEvent(e);
}
);
//-->
</script>
希望本文所述对大家基于javascript的web程序设计有所帮助。
相关文章
关于js复制内容到浏览器剪贴板报错:Cannot read properties of&n
这篇文章主要给大家介绍了关于js复制内容到浏览器剪贴板报错:Cannot read properties of undefined (reading ‘writeText‘)的解决方案,文中给出了详细的原因分析和解决方案,需要的朋友可以参考下2024-01-01详解JavaScript如何创建一个非自动播放的GIF网络组件
这篇文章主要为大家介绍了如何利用JavaScript创建一个允许您的用户决定是否要播放gif的Web组件,文中的实现步骤讲解详细,需要的可以参考一下2022-02-02JavaScript之underscore_动力节点Java学院整理
JavaScript是函数式编程语言,支持高阶函数和闭包。函数式编程非常强大,可以写出非常简洁的代码。下面通过实例讲解JavaScript之underscore的相关知识,一起看看吧2017-07-07sessionStorage存储时多窗口之前能否进行状态共享解析
这篇文章主要为大家介绍了sessionStorage存储时多窗口之前能否进行状态共享解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-02-02Spring Boot+AngularJS+BootStrap实现进度条示例代码
一般上传文件时都需要进度条,本篇文章主要介绍了Spring Boot+AngularJS+BootStrap实现进度条示例代码,有兴趣的可以了解一下。2017-03-03
最新评论