Javascript ternary operator and assignment

36.7k Views Asked by At

I get unexpected result for this simple JavaScript assignment statement:

var t = 1 == 1 ? 1 : 0;
undefined

I would have expected to get 1 assigned to t instead. Same result if you do

var t = (1 == 1 ? 1 : 0);
undefined

Can somebody explain why this does not work as expected?

4

There are 4 best solutions below

6
On

It works perfectly:

> var t = 1 == 1 ? 1 : 0;
undefined
> t
1

You could say that the return value of the assignment operation is undefined, not the value of t.


Edit: But actually if I read the specification correctly, it seems that it should return the value of the expression.

As @T.J. Crowder mentioned, it seems the var is responsible for the undefined value. But that does not mean that you should not use var. The code you wrote is 100% correct.

This goes more into the inner workings of the language and I think that is not what you are interested in. Bur for more information about that, have a look at the comments.

0
On

This code works fine:

var t = 1 == 1 ? 1 : 0;
alert (t);

Check here. It shows 1.

0
On

The result of evaluating var t = 1 == 1 ? 1 : 0; in, say, the Firebug console will be undefined. However, the value of t will be 1 as expected. Try outputting t after the assignment.

Firebug will print the result when the variable declaration is on a separate line:

var t;
t = 1 == 1 ? 1 : 0;

This is because the return value of an assignment operation is the value being assigned. However, when the var keyword is present, what's returning is the value of the VariableStatement declaration, which behaves as follows:

The production VariableStatement : var VariableDeclarationList; is evaluated as follows: Evaluate VariableDeclarationList. Return (normal, empty, empty).

Where Return (normal, empty, empty). refers to a type recognized by JavaScript internally, not something that would be printed to the console.

Further reading:

http://ecma262-5.com/ELS5_HTML.htm#Section_12.2

1
On

In old javascript parsers we need to conclude the condition in parentheses:

var t = (1 == 1) ? 1 : 0;