Выразительный JavaScript (Хавербеке) - страница 144

>  var button = document.querySelector("button");

>  para.addEventListener("mousedown", function() {

>    console.log("Обработчик параграфа.");

>  });

>  button.addEventListener("mousedown", function(event) {

>    console.log("Обработчик кнопки.");

>    if (event.which == 3)

>      event.stopPropagation();

>  });

>

У большинства объектов событий есть свойство >target, ссылающееся на узел, который запустил обработку. Его можно использовать для проверки того, что вы не обрабатываете что-то, пришедшее с ненужного вам узла.

Также возможно использовать свойство >target, чтобы распространить обработку конкретного типа события. К примеру, если у вас есть узел, содержащий длинный список кнопок, было бы удобнее зарегистрировать один обработчик событий для узла, и в нём выяснять, нажали ли на кнопку – вместо того, чтобы регистрировать обработчики каждой кнопки по отдельности.

>

>

>

>

Действия по умолчанию

У многих событий есть действия по умолчанию. При клике на ссылку вы перейдёте по ней. При нажатии на стрелку вниз браузер прокрутит страницу вниз. По правому клику мыши вы увидите контекстное меню. И так далее.

Для большинства типов событий обработчики событий вызываются до того, как сработает действие по умолчанию. Если обработчик не хочет, чтобы это действие происходило (часто потому, что он уже обработал его), он может вызвать метод >preventDefault объекта события.

Это можно использовать для создания своих горячих клавиш или контекстного меню. Также это можно использовать для слома привычного пользователю интерфейса. К примеру, вот ссылка, по которой нельзя пройти.

>MDN

>

Не делайте так – если у вас нет очень серьёзной причины! Пользователям вашей страницы будет очень неудобно, когда они столкнутся с неожиданными результатами своих действий. В зависимости от браузера, некоторые события перехватить нельзя. В Chrome нельзя обрабатывать горячие клавиши закрытия текущей закладки (Ctrl-W или Command-W).

События от кнопок клавиатуры

При нажатии кнопки на клавиатуре браузер запускает событие >"keydown". Когда она отпускается, происходит событие >"keyup".

>

Страница по нажатию V офиолетивает.