JS WAT
Surprising parts of JavaScript


What to expect from the talk?


Will it be useful?



Maybe a little bit ;)
Why I am here?


- To see some crazy examples of JS behaviour
- To laugh


- To understand the logic behind the scenes


[] == [] // false[] == ![] // true
Array is not an Array





The abstract equality operator converts both sides to numbers to compare them, and both sides become the number 0 for different reasons.
Explanation
+[] == +![]0 == +false0 == 0

true + true
// 2
Math is weird





When the plus operator is placed between two booleans, the booleans are converted to numbers
Explanation
Number(true) + Number(true)1 + 1

parseInt("f*ck"); // -> NaN
parseInt("f*ck", 16); // -> 15parseInt is a bad guy





This happens because parseInt will continue parsing character-by-character until it hits a character it doesn't know. The 'f' in 'f*ck' is the hexadecimal digit 15. By default radix is 10 (decimal)
Explanation


999999999999999 // -> 999999999999999
9999999999999999 // -> 1000000000000000010000000000000000;// -> 1000000000000000010000000000000000 + 1 // -> 1000000000000000010000000000000000 + 1.1 // -> 10000000000000002Magically increasing numbers





This is caused by IEEE 754-2008 standard for Binary Floating-Point Arithmetic. At this scale, it rounds to the nearest even number.
Explanation


1 < 2 < 3 // true3 > 2 > 1 // falseComparison knows some jokes





Explanation
1 < 2 < 3 true < 3 1 < 3 // true3 > 2 > 1true > 11 > 1 // false

Math.min(1, 4, 7, 2); // 1
Math.max(1, 4, 7, 2); // 7Math.min() > Math.max(); // trueMath.max() less than Math.min()





Explanation
Math.min(); // Infinity
Math.max(); // -Infinity

null == 0; // falsenull > 0; // falsenull >= 0; // trueComparing null to 0





Explanation
null == 0 // falseIf you have null on one side of the equal sign, the other side must be null or undefined for the expression to return true. Since this is not the case, false is returned.
null > 0 // falseThe algorithm here, unlike that of the abstract equality operator, will convert null to a number.
0 > 0 // falseThe >= operator in fact works in a very different way, which is basically to take the opposite of the < operator.
null >= 0!(null < 0)!(0 < 0)!(false)

[] + {} // "[object Object]"{} + [] // 0Funny math
From transposition of elements a sum does not change
Or does it?





Explanation
{} + []+[] // 0[] + {}[].toString() + ({}).toString()'' + "[object Object]" // "[object Object]"{} parsed as empty block expresion


1 + {} // "1[object Object]"{} + 1 // 1Funny math v2





('b' + 'a' + + 'tman').toUpperCase()// "BANAN"

Batman is not a Hero he used to be





Explanation
('b' + 'a' + + 'tman').toUpperCase()('ba' + (+ 'tman')).toUpperCase()('ba' + NaN).toUpperCase()('ba' + 'NaN').toUpperCase() // BANANThanks for attention



Resourses and Credits


Contacts

Skype: yavorco
Email: roman.yavoriv@techmagic.co


JS WAT
By Roman Yavoriv
JS WAT
Surprising parts of JavaScript
- 479