I was killing time reading the underscore.string functions, when I found this weird shorthand:
function count (str, substr) {
var count = 0, index;
for (var
index >= 0 && count++;
index >= 0
returns true if index
has a value that is greater than or equal to 0
.
a && b
most C-style languages shortcut the boolean ||
and &&
operators.
For an ||
operation, you only need to know that the first operand is true
and the entire operation will return true
.
For an &&
operation, you only need to know that the first operand is false
and the entire operation will return false
.
count++
count++
is equivalent to count += 1
is equivalent to count = count + 1
If the first operand (index >= 0
) of the line evaluates as true
, the second operand (count++
) will evaluate, so it's equivalent to:
if (index >= 0) {
count = count + 1;
}
JavaScript is different from other C-style languages in that it has the concept of truthy
and falsey
values. If a value evaluates to false
, 0
, NaN
, ""
, null
, or undefined
, it is falsey
; all other values are truthy
.
||
and &&
operators in JavaScript don't return boolean values, they return the last executed operand.
2 || 1
will return 2
because the first operand returned a truthy
value, true
or anything else will always return true, so no more of the operation needs to execute. Alternatively, null && 100
will return null
because the first operand returned a falsey
value.
It's equivalent to:
if (index >= 0) {
count = count + 1;
}
&&
is the logical AND operator. If index >= 0
is true, then the right part is also evaluated, which increases count
by one.
If index >= 0
is false, the right part is not evaluated, so count
is not changed.
Also, the &&
is slightly faster than the if
method, as seen in this JSPerf.
It's the same as:
if(index >= 0){
count++;
}
JavaScript will evaluate the left side (index >= 0
), if it's false
the &&
(AND) will short circuit (since false AND anything is false), thus not running `count++.
If it's (index >= 0
) true
, it evaluates the right side (count++
), then it just ignores the output.