Событие jQuery click по ссылке не будет отслеживаться в vaniila JS
Я использую следующую привязку Vanilla для имитации события делегирования jQuery:
document.addEventListener('click', function(e) {
console.log("some element was clicked");
console.log(e.target);
//here's where I would filter by target
});
Все работает нормально, кроме случаев, когда я пытаюсь с помощью jQuery вызвать событие click для элемента ссылки <a href="#">
, Тогда это не будет работать вообще. Обработчик события щелчка ванили не сработает.
Репродукция работает на <b>
элемент
$('button').click(function() {
$('ul').append('<li><b>New</b></li>');
});
document.addEventListener('click', function(e) {
console.log("some element was clicked");
console.log(e.target);
});
$(document).on('keydown', function(){
console.warn("-------Trigger--------")
$('li').find('b').trigger('click');
});
div{
background: yellow;
padding:10px 20px;
border: 1px solid #ccc;
margin: 10px 0;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<button>Add element</button>
<span id="trigger">Trigger</span>
<div>
Just focus the white panel and press any key. That will trigger the jQuery.click() event as you can see in the code.
</div>
<ul>
<li>Old element</li>
<li>Old element</li>
<li><b>Old element</b></li>
</ul>
Вместо этого, если я заменю элемент ссылки на жирный <b>
это работает как ожидалось. В чем дело? Воспроизведение не работает на <a>
элемент
$('button').click(function() {
$('ul').append('<li><a href="#">New</a></li>');
});
document.addEventListener('click', function(e) {
console.log("some element was clicked");
console.log(e.target);
});
$(document).on('keydown', function(){
console.warn("-------Trigger--------")
$('li').find('a').trigger('click');
});
div{
background: yellow;
padding:10px 20px;
border: 1px solid #ccc;
margin: 10px 0;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<button>Add element</button>
<span id="trigger">Trigger</span>
<div>
Just focus the white panel and press any key. That will trigger the jQuery.click() event as you can see in the code.
</div>
<ul>
<li>Old element</li>
<li>Old element</li>
<li><a href="#">Old element</a></li>
</ul>
И нет, я не хочу использовать [0]
как это:
$('li').find('a')[0].click();
Я хочу, чтобы он работал нормально:
$('li').find('a').click();
1 ответ
К сожалению, вы не можете запускать собственные обработчики кликов в jQuery по ссылкам, в исходном коде это отключено, а в комментарии говорится: "Для согласованности между браузерами не запускайте встроенные.click() для ссылок".
Итак, вам нужно будет либо привязать обработчик кликов документа с помощью jQuery $(document).on("click")
или вызвать узлы clickHandler напрямую $('li').find('a')[0].click();