Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Why does $("body") == $("body") return false?

How come the equation in the title is false? How do check if two jQuery selectors point to the same DOM object?

like image 803
burnt1ce Avatar asked Nov 30 '10 17:11

burnt1ce


2 Answers

You are comparing two distinct jQuery objects because you call $() twice (once for each side of the equation), and as MooGoo explains jQuery creates new wrapper objects for each time you call it. That's why the comparison ends up returning false.

You can extract a DOM object from each jQuery object by either using get() or array dereferencing, then compare these elements. The following both return true because both identical selectors match the same body DOM element:

$('body').get(0) == $('body').get(0) $('body')[0] == $('body')[0] 

If you want to test against a jQuery selector, use is(). Note that, unless your selectors are identical, the selectors you use may not necessarily match the same DOM elements (it's still better to use the above). This also returns true:

$('body').is('body') 
like image 140
BoltClock Avatar answered Sep 24 '22 18:09

BoltClock


Because jQuery creates a new wrapper object for each $ call, and in Javascript all objects are distinct, even if they have the exact same properties/methods.

On the other hand, document.body == document.body would evaluate to true.

like image 41
MooGoo Avatar answered Sep 25 '22 18:09

MooGoo