javascript - js操作新开页面会被拦截,如何解决?
高洛峰
高洛峰 2017-06-30 09:56:28
0
8
889

页面上一个按钮,有个onclick事件,点击触发js,发送ajax请求到后台,后台经过一系列判断,返回url到js

<a class="a" id="k_id" href="javascript:void(0);" onclick="test($(this),id1,id2);"></a>
function test(){
    //发送ajax请求...返回一个url
    var url = "ajax请求返回的url";
    
    //js操作将返回的url赋值到页面上的a标签,然后js模拟a标签点击事件
    $(oElement).attr("href",url);
    $(oElement).removeAttr("onclick");
    var id = $(oElement).attr("id");
    document.getElementById(id).click();//这里点击a标签
    
    //这样的操作会被浏览器拦截,
}

求解

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(8)
曾经蜡笔没有小新

你可以直接跳转到该url吧,为啥要模拟点击, 直接 window.location.href = url

洪涛

onclick监听了click事件,这样就先触发调用test方法,一直重复调用了,一直触发不了herf跳转

漂亮男人

发送ajax之后,不用模拟a标签点击事件,直接location.href = 需要跳转的url 就可以了

给我你的怀抱

跳转页面时,没有必要去除 aonclick 事件;
需要去除的话当前方式直接 t.onclick = null; 即可

<a class="a" id="k_id" href="javascript:void(0);" onclick="test(this)">123123</a>
function test(t) {
    var url = "http://www.baidu.com";
    t.setAttribute("href", url);
    t.onclick = null;
    t.click();
}
某草草

可以试试
新开页面:window.location.href = url;
新开窗口:window.open(url);

ringa_lee

直接用window.location.href不是更好吗?

世界只因有你

a标签有默认的click事件,估计onClick与默认事件冲突了。

漂亮男人

是因为有异步操作,浏览器会拦截 window.open()

可以把 ajax 改成同步,或是想办法前端计算 url。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板