forked from vasanthk/js-bits
-
Notifications
You must be signed in to change notification settings - Fork 0
/
this-keyword.js
102 lines (89 loc) · 2.59 KB
/
this-keyword.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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/**
* The elusive `this` keyword in JS
*
* @Reference:
* http://stackoverflow.com/questions/3127429/how-does-the-this-keyword-work
* http://stackoverflow.com/a/33979892/1672655
* http://stackoverflow.com/a/17514482/1672655
* http://javascriptissexy.com/understand-javascripts-this-with-clarity-and-master-it/
* http://www.sitepoint.com/mastering-javascripts-this-keyword/
* http://www.quirksmode.org/js/this.html
*/
// 1. Global this
console.log(this === window); // true
var foo = "bar";
console.log(this.foo); // "bar"
console.log(window.foo); // "bar"
// 2. Function this
foo = "bar";
function testThis() {
this.foo = "foo";
}
console.log(this.foo); //logs "bar"
testThis();
console.log(this.foo); //logs "foo"
// 3. Prototype this
function Thing() {
console.log(this.foo);
}
Thing.prototype.foo = "bar";
var thing = new Thing(); //logs "bar"
console.log(thing.foo); //logs "bar"
// 4. Object this
var obj = {
foo: "bar",
logFoo: function () {
console.log(this.foo);
}
};
obj.logFoo(); //logs "bar"
// 5. DOM Event this
function Listener() {
document.getElementById("foo").addEventListener("click",
this.handleClick);
}
Listener.prototype.handleClick = function (event) {
console.log(this); //logs "<div id="foo"></div>"
};
var listener = new Listener();
document.getElementById("foo").click(); //logs "<div id="foo"></div>"
// 6. HTML this
//<div id="foo" onclick="console.log(this);"></div>
//<script type="text/javascript">
document.getElementById("foo").click(); //logs <div id="foo"...
//</script>
// 7. jQuery this
//<div class="foo bar1"></div>
//<div class="foo bar2"></div>
// <script type="text/javascript">
$(".foo").each(function () {
console.log(this); //logs <div class="foo...
});
$(".foo").on("click", function () {
console.log(this); //logs <div class="foo...
});
$(".foo").each(function () {
this.click();
});
//</script>
// 8. Inside call(), apply() and bind() functions
function add(inc1, inc2) {
return this.a + inc1 + inc2;
}
var o = {a: 4};
document.write(add.call(o, 5, 6) + "<br />"); //15
//above add.call(o,5,6) sets `this` inside
//add() to `o` and calls add() resulting:
// this.a + inc1 + inc2 =
// `o.a` i.e. 4 + 5 + 6 = 15
document.write(add.apply(o, [5, 6]) + "<br />"); //15
// `o.a` i.e. 4 + 5 + 6 = 15
var g = add.bind(o, 5, 6); //g: `o.a` i.e. 4 + 5 + 6
document.write(g() + "<br />"); //15
var h = add.bind(o, 5); //h: `o.a` i.e. 4 + 5 + ?
document.write(h(6) + "<br />"); //15
// 4 + 5 + 6 = 15
document.write(h() + "<br />"); //NaN
//no parameter is passed to h()
//thus inc2 inside add() is `undefined`
//4 + 5 + undefined = NaN</code>