Задать вопрос

Как исправить, чтобы document on click не срабатывал несколько раз?

У меня по ajax подгружается скрипт вместе с окошком.
И там есть обработчики событий on.
Если открываю окошко, получается, что каждый раз вешается обработчик. И в итоге он срабатывает несколько раз.
Вот пример:
$(document).on('click', '#add_item', function(){

});

Как можно это пофиксить, чтобы он срабатывал только один раз ?
  • Вопрос задан
  • 232 просмотра
Подписаться 1 Простой 1 комментарий
Пригласить эксперта
Ответы на вопрос 2
vmakhnyuk
@vmakhnyuk
Frontend developer
$(document).one('click', '#add_item', function(){});
?
Ответ написан
sergiks
@sergiks Куратор тега JavaScript
♬♬
Перенесите скрипт обработчика из подгружаемых ajax'ом фрагментов в страницу, чтобы присутствовал лишь раз.

* * *
Вообще, если не вешать каждый раз новую анонимную функцию, а вынести обработчик во внешнюю функцию, и отказаться от jQuery, то обработчик сработает лишь однажды:
const handler = () => {
  console.log('click');
}
 
document.addEventListener('click', handler);
document.addEventListener('click', handler);
document.addEventListener('click', handler);
// при клике выведет только 1 сообщение в консоль

Но у jQuery иная механика:
$(document).on('click', handler);
$(document).on('click', handler);
$(document).on('click', handler);
// при клике вывалится 3 сообщения
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
Rocket Смоленск
от 80 000 до 130 000 ₽
div. Ставрополь
от 40 000 до 90 000 ₽
Wanted. Санкт-Петербург
До 220 000 ₽
18 дек. 2024, в 12:22
5000 руб./за проект
18 дек. 2024, в 11:57
500 руб./в час