How to Access jQuery's Internal Data
31 Jan 2012As you may or may not be aware as of jQuery 1.7 the whole event system was rewritten from the ground up. The codebase is much faster and with the new .on()
method there is a lot of uniformity to wiring up event handlers.
One used to be able to access the internal events
data and investiate what events are registered on any given element, but recently this internal information has been hidden based on the following ticketβ¦
"Ticket #8921: jQuery Private Data Should Stay Private It seems that the "private" data is ALWAYS stored on the .data(jQuery.expando) - For "objects" where the deletion of the object should also delete its caches this makes some sense. In the realm of nodes however, I think we should store these "private" members in a separate (private) cache so that they don't pollute the object returned by $.fn.data()" --http://bugs.jquery.com/ticket/8921
Although I agree with the above change to hide the internal data, I have found having access to this information can be helpful for debugging and unit testing.
What was the new way of getting the internal jquery event object in jQuery 1.7? /cc @DamianEdwards @elijahmanor β Aaron Powell (@slace) January 30, 2012
Thankfully, if you still need access to the internal data it is still accessible, however, you need to use a method that isnβt officially documentedβ¦ which means that you should be cautious about using it. I would encourage you to not use the undocumented ._data()
method in production code.
You can view, run, and edit the above code sample from JSBin.
On the plus side, if you access the old .data()
method with "events"
as a parameter that will retrieve the internal data containing events and event handlers.
As a side note, if you are looking for events attached using the .live()
or .delegate()
methods then you will need to look at either the document
element or whatever element you delegated against.
Update: Rick Waldron informed me on twitter that the jQuery Core team plans on creating a supported plugin to access the internal data that jQuery maintains. This would be a much better solution than using the above undocumented ._data()
method because undocumented methods are also unsupported methods ;) I only use the ._data()
method for debugging or testing. You should try to avoid using it in any of your production code for this reason.