本文实例讲述了js实现window.open不被拦截的解决方法。分享给大家供大家参考。具体分析如下:
一、问题:
今天在处理页面ajax请求过程中,想实现请求后打开新页面,就想到通过 js window.open 来实现,但是最终都被浏览器拦截了。
二、分析:
在谷歌搜索有没有解决方法,有些说可以通过新建a标签,模拟点击来实现,但是测试发现都实现不了,照样被浏览器拦截。
最后找到了一个折中的办法,可以实现新页面打开,但是没有a标签的那种直接流量新页面的效果。
三、实现代码:
立即学习“Java免费学习笔记(深入)”;
$obj.click(function(){
var newTab=window.open('about:blank');
$.ajax({
success:function(data){
if(data){
//window.open('http://www.jb51.net');
newTab.location.href="http://www.jb51.net";
}
}
})
})
其它方法:
<script type="text/javascript"><br>
<!-- <br>
$( <br>
function()<br>
{<br>
//方法一<br>
window.showModalDialog("http://www.jb51.net/");<br>
window.showModalDialog("http://www.jb51.net/");<br>
<p>//方法二<br>
var aa=window.open();<br>
setTimeout(function(){<br>
aa.location="http://www.jb51.net";<br>
}, 100);<br>
<p>var b=window.open();<br>
setTimeout(function(){<br>
b.location="http://www.jb51.net";<br>
}, 200);<br>
<p>var c=window.open();<br>
setTimeout(function(){<br>
c.location="http://www.jb51.net";<br>
}, 300);<br>
<p>var d=window.open();<br>
setTimeout(function(){<br>
d.location="http://www.jb51.net";<br>
}, 400);<br>
<p>var ee=window.open();<br>
setTimeout(function(){<br>
ee.location="http://www.jb51.net";<br>
}, 500);<br>
<p>var f=window.open();<br>
setTimeout(function(){<br>
f.location="http://www.jb51.net";<br>
}, 600);<br>
<p>var g=window.open();<br>
setTimeout(function(){<br>
g.location="http://www.jb51.net";<br>
}, 700);<br>
<p>var h=window.open();<br>
setTimeout(function(){<br>
h.location="http://www.jb51.net";<br>
}, 800);<br>
<p>var i=window.open();<br>
setTimeout(function(){<br>
i.location="http://www.jb51.net";<br>
}, 900);<br>
<p>var j=window.open();<br>
setTimeout(function(){<br>
j.location="http://www.jb51.net";<br>
}, 1000);<br>
<p>//方法三<br>
var a = $("<a href='http://www.jb51.net' target='_blank'>Apple").get(0);<br>
var e = document.createEvent('MouseEvents');<br>
e.initEvent( 'click', true, true );<br>
a.dispatchEvent(e);<br>
<p>var a = $("<a href='http://www.jb51.net' target='_blank'>Apple").get(0);<br>
var e = document.createEvent('MouseEvents');<br>
e.initEvent( 'click', true, true );<br>
a.dispatchEvent(e);<br>
}<br>
<br>
);<br>
//--><br>
</script>
希望本文所述对大家基于javascript的web程序设计有所帮助。