tags:

views:

171

answers:

5

I am using a large JS library to perform certain drawing operations in canvas. Reviewing the library code (to make accommodating changes), I have ran into the '||' operator being used in a fashion which certainly should not evaluate to Boolean. Does this mean that this is a different operator or am I missing something obvious? An example follows:

var $time = Date.now || function(){
return +new Date;
};
+7  A: 

The || operator evaluates to the first operand if it can be converted to true or the last operand otherwise. So in your example $time will be Date.now if it exists or the declared function otherwise.

Gumbo
The first non-False operant, that is.
cpharmston
Thanks :)
Crimson
Not the first operand that can be converted to true. The last expression is used even if it would be converted to false.
googletorp
A: 

This is very common is javascript. If Data.now evaluates to true, then $time is set to that, else it is set to the function.

googletorp
The function doesn't have () attached to the closing brace, so $time is set to the function, not it's output.
David Dorward
Ah yes you are correct missed that in the haste. Updated.
googletorp
A: 

I believe that code is saying if the DateTime.now variable does not exist, instead return the result of +new Date.

Noon Silk
It could also be saying DateTime.now is '', 0, false, null
I.devries
A: 

The || operator is being used to assign a value to $time in the example.

If Date.now evaluates to false, then $time is assigned the value on the right side of the || operator (in this case, a function). If Date.now evaluates to true, then it short-cicuits and assigns the value of Date.now to $time

Russ Cam
+6  A: 

There is already an accepted answer, but I like to mention, that the OR-Operator is also called Default-Operator, because it doesn't return a boolean, but instead the left or right hand argument.

Same goes for the AND-Operator, which is also called guard-Operator.

Check out crockford's Survey of the JavaScript Programming Language for more details:

The && operator is commonly called logical and. It can also be called guard. If the first operand is false, null, undefined, "" (the empty string), or the number 0 then it returns the first operand. Otherwise, it returns the second operand. This provides a convenient way to write a null-check:

var value = p && p.name; /* The name value will only be retrieved from p if p has a value, avoiding an error. */

The || operator is commonly called logical or. It can also be called default. If the first operand is false, null, undefined, "" (the empty string), or the number 0, then it returns the second operand. Otherwise, it returns the first operand. This provides a convenient way to specify default values:

value = v || 10; /* Use the value of v, but if v doesn't have a value, use 10 instead. */

Tim Büthe