Maison > Questions et réponses > le corps du texte
Il existe un événement onclick pour un bouton sur la page. Le clic déclenche js et envoie une requête ajax à l'arrière-plan. Après une série de jugements, l'arrière-plan renvoie l'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标签
//这样的操作会被浏览器拦截,
}
求解
曾经蜡笔没有小新2017-06-30 09:58:28
Vous pouvez accéder directement à l'url. Pourquoi souhaitez-vous simuler un clic ? Direct window.location.href = url
PHP中文网2017-06-30 09:58:28
onclick surveille l'événement click, il déclenche donc d'abord l'appel à la méthode de test et continue de l'appeler à plusieurs reprises, mais le saut herf ne peut pas être déclenché
漂亮男人2017-06-30 09:58:28
Après l'envoi d'ajax, il n'est pas nécessaire de simuler un événement de clic de balise, définissez simplement location.href = l'URL qui doit être sautée
给我你的怀抱2017-06-30 09:58:28
Lorsque vous accédez à la page, il n'est pas nécessaire de la supprimer a
的 onclick
事件;
需要去除的话当前方式直接 t.onclick = null;
juste
<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();
}
某草草2017-06-30 09:58:28
Vous pouvez l'essayer
Ouvrez une nouvelle page : window.location.href = url;
Ouvrez une nouvelle fenêtre : window.open(url);
ringa_lee2017-06-30 09:58:28
N'est-il pas préférable d'utiliser window.location.href directement ?
世界只因有你2017-06-30 09:58:28
La balise
a a un événement de clic par défaut. On estime que onClick est en conflit avec l'événement par défaut.
漂亮男人2017-06-30 09:58:28
Parce qu'il y a des opérations asynchrones, le navigateur interceptera window.open()
.
Vous pouvez changer ajax en synchronisation ou trouver un moyen de calculer l'URL sur le front-end.