一、问题:
今天在处理页面ajax请求过程中,想实现请求后打开新页面,就想到通过 js window.open 来实现,但是最终都被浏览器拦截了。
二、分析:
在谷歌搜索有没有解决方法,有些说可以通过新建a标签,模拟点击来实现,但是测试发现都实现不了,照样被浏览器拦截。
最后找到了一个折中的办法,可以实现新页面打开,但是没有a标签的那种直接流量新页面的效果。
三、实现代码:
代码如下:$obj.click(function(){
var newTab=window.open('about:blank');
$.ajax({
success:function(data){
if(data){
//window.open('http://www.gxlcms.com');
newTab.location.href="http://www.gxlcms.com";
}
}
})
})
其它方法:
代码如下:
var b=window.open();
setTimeout(function(){
b.location="http://www.gxlcms.com";
}, 200);
var c=window.open();
setTimeout(function(){
c.location="http://www.gxlcms.com";
}, 300);
var d=window.open();
setTimeout(function(){
d.location="http://www.gxlcms.com";
}, 400);
var ee=window.open();
setTimeout(function(){
ee.location="http://www.gxlcms.com";
}, 500);
var f=window.open();
setTimeout(function(){
f.location="http://www.gxlcms.com";
}, 600);
var g=window.open();
setTimeout(function(){
g.location="http://www.gxlcms.com";
}, 700);
var h=window.open();
setTimeout(function(){
h.location="http://www.gxlcms.com";
}, 800);
var i=window.open();
setTimeout(function(){
i.location="http://www.gxlcms.com";
}, 900);
var j=window.open();
setTimeout(function(){
j.location="http://www.gxlcms.com";
}, 1000);
//方法三
var a = $("Apple").get(0);
var e = document.createEvent('MouseEvents');
e.initEvent( 'click', true, true );
a.dispatchEvent(e);
var a = $("Apple").get(0);
var e = document.createEvent('MouseEvents');
e.initEvent( 'click', true, true );
a.dispatchEvent(e);
}
);
//-->
script>
希望本文所述对大家基于javascript的web程序设计有所帮助。
声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com