javascriptif-statementshorthandshorthand-if

Shorthand if/else statements : foo?foo:bar vs foo || bar


I wonder how this two are different ?

var hello = foo?foo:bar;

vs

var hello = foo || bar;

Can you explain this ? and some case example ? or both are same ?

PS : foo/bar should be all like string / int / obj / boolean...


Solution

  • The ? : is called the conditional operator It takes three arguments (which is why it's sometimes called the "ternary" operator): Something to test, something to return if the test is truthy, and something to return if the test is falsey.*

    The second is JavaScript's curiously-powerful logical OR operator. It accepts two arguments. It evaluates the first operand and, if that's truthy, returns it; if the first is falsey, it evaluates and returns the second operand.

    So the difference between those two is this: With the conditional operator, foo may be evaluated twice (if it's truthy). With the ||, foo is only evaluated once. It doesn't really matter if foo and bar are just simple variable references, but consider:

    var hello = foo() ? foo() : bar();
    // vs
    var hello = foo() || bar();
    

    You can see how it matters how many times foo() is evaluated, if it does any significant work or has any side effects.


    (* So what are "truthy" and "falsey" values? The "falsey" values are 0, "", NaN, undefined, null, and of course false. Everything else is "truthy".)