Если потребуется удалить только те обработчики событий, которые были зарегистрированы вами, и вы не использовали пространства имен, вы должны получить ссылки на функции обработчиков событий и использовать версию вызова метода
<b>unbind()</b>
с двумя аргументами. В этом случае в первом аргументе передается строка с типом события (без указания пространств имен), а во втором - функция-обработчик:
<b>$('flmybutton').unbind('click', myClickHandler);</b>
При вызове метода
<b>unbind()</b>
таким способом он удалит указанный обработчик указанного типа (или типов) события из всех выбранных элементов в объекте
<b>jQuery</b>
. Обратите внимание, что обработчики событий могут удаляться версией метода
<b>unbind()</b>
с двумя аргументами, даже когда они были зарегистрированы с дополнительными данными, с помощью версии метода
<b>bind(),</b>
принимающей три аргумента.
Методу
<b>unbind()</b>
можно также передавать объект в единственном аргументе. В этом случае метод
<b>unbind()</b>
будет вызываться рекурсивно для каждого свойства объекта. Имена свойств этого объекта должны определять типы событий, а значения -функции обработчиков:
<b>$('а').unbind({ // Удалить конкретные обработчики событий mouseover и mouseout </b>
<b> mouseover: mouseoverHandler.</b>
<b> mouseout: mouseoutHandle г</b>
<b>});</b>
Наконец, существует еще один способ вызова метода
<b>unbind().</b>
Если передать ему объект
<b>Event</b>
, созданный библиотекой jQuery, он удалит обработчики событий, которым будет передано это событие. Вызов
<b>unbind(ev)</b>
эквивалентен вызову
<b>unbind(ev.type, ev.handler)</b>
.
19.4.6. Возбуждение событий
Зарегистрированные обработчики событий будут вызываться автоматически, когда пользователь начнет использовать мышь или клавиатуру или когда будут возникать события других типов. Однако иногда бывает полезно генерировать события вручную. Проще всего сделать это, вызвав один из простых методов регистрации обработчиков (такой как
<b>click()</b>
или
<b>mouseover()</b>
) без аргументов. Подобно многим методам объекта
<b>jQuery</b>
, которые могут играть роль методов чтения и записи, эти методы регистрируют обработчики событий, когда вызываются с аргументами, и запускают их, когда вызываются без аргументов. Например:
<b>$("#my_form").submit(); // Будет действовать, как если бы пользователь щелкнул</b>
<b> // на кнопке отправки формы</b>
Метод
<b>submit(</b>
) в инструкции выше синтезирует объект
<b>Event</b>
и запустит все обработчики событий, которые были зарегистрированы для события «submit». Если ни один из этих обработчиков не вернет false или не вызовет метод
<b>preventDefault()</b>
объекта
<b>Event</b>
, форма действительно будет отправлена. Обратите внимание, что события будут всплывать, даже если сгенерировать их вручную, как в данном примере. Это означает, что возбуждение события в множестве выбранных элементов может также привести к вызову обработчиков событий в предках этих элементов.
Важно отметить, что методы объекта
<b>jQuery</b>
, генерирующие события, будут запускать любые обработчики событий, зарегистрированные методами объекта
<b>jQuery</b>
, а также обработчики, объявленные в HTML-атрибутах или свойствах объектов
<b>Element</b>
, таких как
<b>onsubmit</b>
. Но с их помощью невозможно вручную запустить обработчики событий, зарегистрированные методом
<b>addEventListener()</b>
или
<b>attachEvent()</b>
(однако эти обработчики по-прежнему будут вызываться при возникновении настоящих событий).
Отметьте также, что механизм возбуждения событий в библиотеке jQuery является синхронным - в нем не используется очередь событий. Когда событие генерируется вручную, обработчики событий будут вызваны немедленно, до того как метод, возбудивший событие, вернет управление. Если вы генерируете событие «click» и один из запущенных обработчиков сгенерирует событие «submit», все обработчики события «submit» будут вызваны до того, как будет вызван следующий обработчик события «click».
Методы, такие как
<b>submit(),</b>
удобно использовать для связывания и возбуждения событий; но как библиотека jQuery определяет более обобщенный метод
<b>bind(),</b>
так же она определяет и более обобщенный метод
<b>trigger().</b>
Обычно при вызове в первом аргументе методу
<b>trigger()</b>
передается строка с типом события, и он запускает обработчики, зарегистрированные для этого типа во всех выбранных элементах в объекте
<b>jQuery</b>
. То есть вызов
<b>submit()</b>
в примере выше эквивалентен вызову:
<b>$("#my_form").trigger("submit");</b>
В отличие от методов
<b>bind()</b>
и
<b>unbind(),</b>
в вызове метода
<b>trigger()</b>
нельзя указать более одного типа события в первом аргументе. Однако, подобно методам
<b>bind()</b>
и
<b>unbind(),</b>
он позволяет указывать пространства имен возбуждаемых событий» чтобы запустить только обработчики, зарегистрированные для этого пространства имен. Если потребуется запустить только обработчики событий, не привязанные ни к какому пространству имен, следует добавить в строку с типом события восклицательный знак. Обработчики, зарегистрированные посредством свойств, таких как
<b>onclick</b>
, считаются обработчиками, не привязанными к какому-либо пространству имен: