0 / 0 / 0
Регистрация: 18.12.2014
Сообщений: 2

Событие на document

18.12.2014, 17:38. Показов 535. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.

Имеется некий класс с несколькими методами. + Довольно стандартные строки навешивания события на элемент.

Код JS.

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
function Widjet() {
    this.id = null;
    this.jqlink = null;
    this.type = null;
    this.add = function () {
    };
    this.remove = function () {
    };
    this.copy = function () {
    };
    this.lock = function () {
    };
    this.unlock = function () {
    };
    this.edit = function () {
    };
    this.activate = function () {
        $(document).on('click', function () {
            console.log('123');
        });
    };
    this.deactivate = function () {
    };
    this.hovered = function () {
    };
    this.dehovered = function () {
    };
    this.getSerialize = function () {
    };
    this.load = function () {
    };
}
var widjet = new Widjet();
$(document).ready(function () {
    $('#button').click(function () {
        widjet.activate();
    });
});

Описание:
При клике на элемент #button, вызывается метод activate, внутри которого вешается событие на document. При последующих кликах на document в консоль должно выводиться 123.

Проблема:
При первом клике на #button в консоль сразу выводится 123, но по логике не должно, т.к. событие на document еще не висит. В чем может быть проблема?
Вложения
Тип файла: zip test.zip (33.2 Кб, 1 просмотров)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.12.2014, 17:38
Ответы с готовыми решениями:

Делегировать событие 'focus' с document на input
Всем привет. Подскажите как можно делегировать событие 'focus' с document на input (vanilla js). С 'click' работает, а с 'focus' и...

Событие onMouseOver внутри document.write
Доброго времени суток!!! Как сделать, чтобы ЯваСкрипт выводил тег (например div) с событием onMouseOver, и чтобы при наведении в...

Ошибка в var iScrollTop = document.Fr1.document.body.ScrollTop;
есть страничка, на ней <IFRAME name='Fr1'></IFRAME>. Так вот когда я пишу var iScrollTop = document.Fr1.document.body.ScrollTop; то...

1
0 / 0 / 0
Регистрация: 18.12.2014
Сообщений: 2
18.12.2014, 17:59  [ТС]
Вопрос решен.
Ответ для тех, кто столкнется с такой же проблемой:

Событие click - "всплывающее". Оно проходит последовательно вверх по всем предкам элемента, достигая document и window. Таким образом когда событие обрабатывается самим элементом ты навешиваешь обработчик на document, затем событие всплывает постепенно до document и обрабатывает тот самый обработчик.

Остановить всплытие можно через event.stopPropagation()
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.12.2014, 17:59
Помогаю со студенческими работами здесь

Разница между document.querySelectorAll() и document.body.getElementByClassNam()
И document.querySelectorAll("selector") и document.body.getElementsByClassNam("selector") возвращают массив найденных элементов по...

Как это работает (function(document) {.})(document);?
Добрый день! Нашёл замечательный скрипт menu effects. Хочу прикрутить к своему сайту. Во всех браузерах работает правильно, но в IE 11...

document.URL or document.location.href
есть документ из трёх фреймов. При загрузке второго фрейма (2) в первом фрейме (1) в поле 'log' должен появлятся адрес второго фрейма...

Разница между document.body и document
Есть две разные строки для присвоения тегу <h1> текста: document.body.getElementsByTagName("h1").innerHTML = "My information"; ...

При попытке frame2.document.innerHTML дает: script error, Acces is denied, хотя alert(frame2.document) выдает нормально: [object]
Есть frameset и 2 frame fram1 - грузится моя страница со скриптами frame2 - грузится удаленная страничка, главное штоб не локальная ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru