Вход/Регистрация
JavaScript. Подробное руководство, 6-е издание
вернуться

Флэнаган Дэвид

Шрифт:

$('а').unbind("click.ns1.ns2");

Если потребуется удалить только те обработчики событий, которые были зарегистрированы вами, и вы не использовали пространства имен, вы должны получить ссылки на функции обработчиков событий и использовать версию вызова метода

unbind
с двумя аргументами. В этом случае в первом аргументе передается строка с типом события (без указания пространств имен), а во втором - функция-обработчик:

$('flmybutton').unbind('click', myClickHandler);

При вызове метода

unbind
таким способом он удалит указанный обработчик указанного типа (или типов) события из всех выбранных элементов в объекте
jQuery
. Обратите внимание, что обработчики событий могут удаляться версией метода
unbind
с двумя аргументами, даже когда они были зарегистрированы с дополнительными данными, с помощью версии метода
bind,
принимающей три аргумента.

Методу

unbind
можно также передавать объект в единственном аргументе. В этом случае метод
unbind
будет вызываться рекурсивно для каждого свойства объекта. Имена свойств этого объекта должны определять типы событий, а значения -функции обработчиков:

$('а').unbind({ // Удалить конкретные обработчики событий mouseover и mouseout

mouseover: mouseoverHandler.

mouseout: mouseoutHandle г

});

Наконец, существует еще один способ вызова метода

unbind.
Если передать ему объект
Event
, созданный библиотекой jQuery, он удалит обработчики событий, которым будет передано это событие. Вызов
unbind(ev)
эквивалентен вызову
unbind(ev.type, ev.handler)
.

19.4.6. Возбуждение событий

Зарегистрированные обработчики событий будут вызываться автоматически, когда пользователь начнет использовать мышь или клавиатуру или когда будут возникать события других типов. Однако иногда бывает полезно генерировать события вручную. Проще всего сделать это, вызвав один из простых методов регистрации обработчиков (такой как

click
или
mouseover
) без аргументов. Подобно многим методам объекта
jQuery
, которые могут играть роль методов чтения и записи, эти методы регистрируют обработчики событий, когда вызываются с аргументами, и запускают их, когда вызываются без аргументов. Например:

$("#my_form").submit; // Будет действовать, как если бы пользователь щелкнул

// на кнопке отправки формы

Метод

submit(
) в инструкции выше синтезирует объект
Event
и запустит все обработчики событий, которые были зарегистрированы для события «submit». Если ни один из этих обработчиков не вернет false или не вызовет метод
preventDefault
объекта
Event
, форма действительно будет отправлена. Обратите внимание, что события будут всплывать, даже если сгенерировать их вручную, как в данном примере. Это означает, что возбуждение события в множестве выбранных элементов может также привести к вызову обработчиков событий в предках этих элементов.

Важно отметить, что методы объекта

jQuery
, генерирующие события, будут запускать любые обработчики событий, зарегистрированные методами объекта
jQuery
, а также обработчики, объявленные в HTML-атрибутах или свойствах объектов
Element
, таких как
onsubmit
. Но с их помощью невозможно вручную запустить обработчики событий, зарегистрированные методом
addEventListener
или
attachEvent
(однако эти обработчики по-прежнему будут вызываться при возникновении настоящих событий).

Отметьте также, что механизм возбуждения событий в библиотеке jQuery является синхронным - в нем не используется очередь событий. Когда событие генерируется вручную, обработчики событий будут вызваны немедленно, до того как метод, возбудивший событие, вернет управление. Если вы генерируете событие «click» и один из запущенных обработчиков сгенерирует событие «submit», все обработчики события «submit» будут вызваны до того, как будет вызван следующий обработчик события «click».

Методы, такие как

submit,
удобно использовать для связывания и возбуждения событий; но как библиотека jQuery определяет более обобщенный метод
bind,
так же она определяет и более обобщенный метод
trigger.
Обычно при вызове в первом аргументе методу
trigger
передается строка с типом события, и он запускает обработчики, зарегистрированные для этого типа во всех выбранных элементах в объекте
jQuery
. То есть вызов
submit
в примере выше эквивалентен вызову:

  • Читать дальше
  • 1
  • ...
  • 356
  • 357
  • 358
  • 359
  • 360
  • 361
  • 362
  • 363
  • 364
  • 365
  • 366
  • ...

Ебукер (ebooker) – онлайн-библиотека на русском языке. Книги доступны онлайн, без утомительной регистрации. Огромный выбор и удобный дизайн, позволяющий читать без проблем. Добавляйте сайт в закладки! Все произведения загружаются пользователями: если считаете, что ваши авторские права нарушены – используйте форму обратной связи.

Полезные ссылки

  • Моя полка

Контакты

  • chitat.ebooker@gmail.com

Подпишитесь на рассылку: