I am going to analyze several internet memes that make fun of javascript. It is a good opportunity to explain each one of them and that the results obtained are not language errors, but there are very specific and serious explanations behind it.
Is important to study first a concept called "type coercion", is about the conversion of
data types in different situations. Continue reading in this link:
https://2ality.com/2019/10/type-coercion.html#what-is-type-coercion%3F
Thanks for JS - meme
Here there are a lot of concept to study.
1) typeof NaN = "number"
Is true, in JS the NaN is a number and can't be compared with any other NaN.
Some read: https://developer.mozilla.org/es/docs/Web/JavaScript/Referencia/Objetos_globales/NaN
Example: NaN==NaN - false
2) 9999999999999999 -> 10000000000000000
Javascript doesn't have integers, only 64-bit floats - and you've ran out of floating-point precision represented with the
constant Number.MAX_SAFE_INTEGER constant.
3) 0.5+0.1==0.6 - true
Is a classic operation, 0.5+0.1 is realized and the result is 0.6 and the value is the same so is true.
4) 0.1+0.2==0.3 - false
- 0.1+0.2 = 0.30000000000000004
- 0.30000000000000004 = 0.6 - false
5) Math.max() = - Infinity
The result is β-Infinityβ if no arguments are passed and the result is NaN if at least
one of the arguments cannot be converted to a number.
6) Math.min() = Infinity
The smallest of the given numbers. If any one or more of the parameters cannot be converted into a number, NaN is returned. The result is Infinity if no parameters are provided.
7) []+[]=""
This happen, because the empty array is casted to "" so ""+"" is equal "".
8) []+{}="[object object]"
The [] is in the left so is casted as string.
- []+{}
- ""+{}
- "[object object]""
9) {}+[]=0
The {} is in the left, so the empty structure is casted to number.
- {} is casted to 0.
- [] is casted to 0.
- 0+0 = 0.
10) true+true+true === 3 - true
true is casted to 1 when is used with the + operator, so is converted to 1+1+1.
11) true-true = 0
true is casted to 1 for the minus operator, so is converted to 1-1.
12) true==1 - true
1 is casted to boolean, Boolean(1) = true, so true==true.
13) true===1 - false
This is beacuse the == operator don't make conversion so the boolean and number are'nt differnt data types.
14) (!+[]+[]+![]).length = 9
Some thins to analize.
- []+[]="".
- ![] = false.
- (!+[]): true, ([]+![]): "false" as string.
- "truefalse" two string concatenated.
- "truefalse".length = 9
15) 9+"1"
"91" the nine is casted to string, so is string+string concatenation = "91".
15) 91-"1" = 90
The 1 is casted from string to number for the use of the operator minus "-". 91-1 = 90.
16) []==0 - true
Array to number conversion, Number([]) is 0, so 0==0.
Fav language JS - meme
Classic meme, here there are one concept.
1) "11"+1 = "111"
Concatenation between string and number the, last is casted to string, easy.
2) "11"-1 = 10
OK, in this case there a string and a number with the minus operator, the string is casted to number, and later
a normal arithmetic operation between two numbers.
- "11" - 1
- 11 - 1
- 10
Patricio - meme
I will analyze this meme, has 3 points.
1) 0 == "0" - true
Converts the variable values to the same type before performing comparison, for this reason the "0" is cast
from string to number and later compare 0 == 0 is the same.
2) 0 == [] - true
hahaha this is very strange, but the explanation is the next:
- The left operand is number.
- The rigth operand is casted to array to number.
- Number([]) = false, the false is casted to number.
- Number(false) = 0.
- 0 == 0 is true.
3) Here they assume that there is a transitivity between 1 and 2.
The logic is if 0 == "0" and 0 == [] then "0" = [], the problem is that the "0" is a string casted to int when is compared,
for this reason the transitive property can't be applyed here.
4) "0" == [] - false
Is correct because the [] is casted to string, String([])="" so "0" == "" is false.
Mind explosion JS - meme
I will analyze this meme, has 4 points.
1) 2+2 = 4
A very normal arithmetic operation, nothing strange.
2) "2"+"2"="22"
A string concatenation, happen when the "+" is used with STRING+STRING.
3) 2+2-2 = 2
Another arithmetic operation, in this case all number are used.
- (2+2)-2
- 4-2
- 2
4) "2"+"2"-"2" = 20
We mix string concatenation and type coercion.
- "2"+"2" = "22 string concatenation
- "22"-"2" = 20
- Type coercion to int, caused by the minus operator.
- "22" - "2", cast "string-string" to "int-int".
- 22 - 2 = 20
Top comments (2)
And one more "feature" with sort:
Not that it changes the overall message; you made a typo in section 4 (of the first meme). A 0.6 should be 0.3