Why {} != ( {} ) in JavaScript?
Asked Answered
O

2

16

It's commonly known that {} is shorter way to define an object like [] is for an array.

But now I am wondering why:

{} != ({})
  • {} evaluates to undefined
  • ({}) evaluates to "correct" Object

Why is JavaScript behaving like this ?

For example 1 equals to (1), so why {} not equals to ({}) ?

Oophorectomy answered 2/1, 2013 at 1:23 Comment(4)
{} != ({}) is a syntax error.Kuska
1 and {} are quite different beasts.Jeramie
By the way the same applies to arrays for similar reasons (because arrays are also objects): [] != [] is true.Luht
Check out Bizzare Javascript Behaviours, with its amazingly detailed answer.Participate
C
24
{} != ({})

This is a syntax error.

SyntaxError: Unexpected token !=

{} is ambigious like that. Is it an empty block, or an empty object literal? It's failing because a comparison operator can not follow a block.

Wrapping it with parenthesis makes the parser treat it as an expression. An expression can't contain a block, so it knows it's an object.

However, if you wrap that comparison in an expression...

({} != ({}))

...it's still true because variables which have an object assigned to them's values are a pointer to them and as a consequence, they are never copied around by their contents (though this is irrelevant to your example). Because of this, their pointer is always different and the comparison fails.

This also implies that comparing two variables which point to the same object will work as expected, as their pointers will be the same.

Censure answered 2/1, 2013 at 1:25 Comment(2)
Can you tell me what it does here /*Instance methods*/ hasOwn = ({}).hasOwnProperty, in the jQuery source? (Y)Coffey
@dollarVar That could be its own question. It's the same thing, the authors want a reference to Object.prototype.hasOwnProperty, but are accessing it via an object literal. Due to ambiguity as mentioned in my answer, it must be wrapped in parenthesis, otherwise it's parsed as a block and there is no property lookups on blocks :)Censure
R
5

{} != {} is true because both {}'s are completely different objects. However, variables that are referencing the same object hold equality:

​var a = {},
    b = a;

assert( a == b )​
Rosaleerosaleen answered 2/1, 2013 at 1:25 Comment(2)
Aren't you supposed to use === in Javascript to check on references?Sensitive
@Kevin: === is about types. Objects are always compared by referencesCagey

© 2022 - 2024 — McMap. All rights reserved.