forked from vasanthk/js-bits
-
Notifications
You must be signed in to change notification settings - Fork 0
/
coercion.js
72 lines (59 loc) · 2.47 KB
/
coercion.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/**
* Coercion:
* Converting a value from one type to another is often called "type casting," when done explicitly,
* and "coercion" when done implicitly (forced by the rules of how a value is used)
*
* == vs ===
* The identity (===) operator behaves identically to the equality (==) operator except no type conversion is done,
* and the types must be the same to be considered equal.
*
* The == operator will compare for equality after doing any necessary type conversions.
* The === operator will not do the conversion, so if two values are not the same type === will simply return false.
* It's this case where === will be faster, and may return a different result than ==. In all other cases performance will be the same.
*
* Links:
* http://stackoverflow.com/questions/359494/does-it-matter-which-equals-operator-vs-i-use-in-javascript-comparisons
* http://davidwalsh.name/fixing-coercion#isnt-coercion-already-dead
* http://bytearcher.com/articles/equality-comparison-operator-javascript/
* http://rainsoft.io/the-legend-of-javascript-equality-operator/
* http://bytearcher.com/articles/equality-comparison-operator-javascript/
*/
// Coercion in JS
(function () {
var x = 42;
var y = x + ""; // implicit coercion!
console.log(y); // "42"
var z = String(x); // explicit coercion!
console.log(z); // "42"
})();
// Equality checks - Crazyyy Sh*t!!!
(function () {
console.log('' == '0'); // false
console.log(0 == ''); // true
console.log(0 == '0'); // true
console.log(false == 'false'); // false
console.log(false == '0'); // true
console.log(false == undefined); // false
console.log(false == null); // false
console.log(null == undefined); // true
console.log(' \t\r\n ' == 0); // true
// Array
var a = [1, 2, 3];
var b = [1, 2, 3];
console.log(a == b); // false
console.log(a === b); // false
// Object
var c = {x: 1, y: 2};
var d = {x: 1, y: 2};
console.log(c == d); // false
console.log(c === d); // false
// String
var e = "text";
var f = "te" + "xt";
console.log(e == f); // true
console.log(e === f); // true
// Here the == operator is checking the values of the two objects and returning true,
// but the === is seeing that they're not the same type and returning false.
console.log("abc" == new String("abc")); // true
console.log("abc" === new String("abc")); // false
})();