As of jQuery 1.7, the on
docs function is used to replace the existing separate methods of binding events:
one
docs is a special case, and you should continue to use it as is.
The existing events continue to exist, and are simply aliases of on
. There is no official report to suggest that they will be removed, so you'd be safe to continue to use them if you understand them better. live
and die
have been deprecated as of jQuery 1.7 as mentioned in a blog post and on the live
docs.
The on
event has multiple formats, but the function signature is as follows:
.on( events [, selector] [, data], handler )
Bind:
$(selector).bind(events, data, handler);
$(selector).on(events, null, data, handler);
Source:
bind: function( types, data, fn ) {
return this.on( types, null, data, fn );
}
Delegate:
$(selector).delegate(subselector, events, data, handler);
$(selector).on(events, subselector, data, handler);
Source:
delegate: function( selector, types, data, fn ) {
return this.on( types, selector, data, fn );
}
Live:
$(selector).live(events, data, handler);
$(document).on(events, selector, data, handler);
Source:
live: function( types, data, fn ) {
jQuery( this.context ).on( types, this.selector, data, fn );
return this;
}
Note that this.context
was set using this.context = document;
as specified at $(document).on(...)
.