ð ð ð 40 questions to solve JavaScript this
Five ways to bind this
-
Default binding (non-strict mode refers to global object, strict mode binds this to undefined)
-
Implicit binding (when a function references a context object, such as the way obj.foo() is called, where this in foo refers to obj)
-
Show bindings (specify this bindings directly via call() or apply(), such as foo.call(obj))
-
The new binding
-
Arrow function binding (the reference of this is determined by outer scope)
The default binding
In non-strict mode
The variables declared by var become properties of the window
Function will become the window method
So this inside function points to the window
var a = 10;
function foo() {
console.log(this.a);
}
foo(); / / 10
window.a; / / 10
window.foo; // foo(){}
Copy the code
But strictly global this points to undefined
Implicit binding
This always refers to the object that last called it
var a = 2;
function foo() {
console.log(this.a);
}
var bar = {
a: 1,
foo,
};
bar.foo(); / / 1
Copy the code
The new binding
function Person(name) {
this.name = name;
}
var name = 'window';
var person1 = new Person('chou');
console.log(person1.name); // chou
Copy the code
According to the binding
Note that apply and call execute methods but bind does not
So just to summarize this part of the knowledge point
-
This always refers to the object that last called it
-
The this of an anonymous function always points to the window
-
Functions that use.call() or.apply() are executed directly
-
Bind () creates a new function that needs to be called manually
-
Call, apply, or bind will ignore this argument if the first argument received by call, apply, or bind is null or undefined
-
The second argument to the forEach, map, and filter functions can also be explicitly bound to this
Arrow function
-
There is no this binding in the arrow function and its value must be determined by looking up the scope chain
-
If the arrow function is contained by a non-arrow function, then this is bound to this of the nearest non-arrow function; otherwise, this is undefined
-
Not modified by methods such as Apply
The arrow function this cannot be changed directly by bind, call, or apply
But it can be changed indirectly by changing the direction of this in scope
var name = 'window';
var obj1 = {
name: 'obj1'.foo1: function () {
console.log(this.name);
return () = > {
console.log(this.name);
};
},
foo2: () = > {
console.log(this.name);
return function () {
console.log(this.name); }; }};var obj2 = {
name: 'obj2'}; obj1.foo1.call(obj2)(); obj1.foo1().call(obj2); obj1.foo2.call(obj2)(); obj1.foo2().call(obj2);Copy the code
-
Obj1.foo1.call (obj2)() the first layer is a normal function and changes this to obj2 via.call, so it prints obj2. The second layer is an arrow function whose this is the same as this in the outer scope and is therefore obj2.
-
Obj1.foo ().call(obj2) Prints obj1 on the first layer, and the arrow function on the second layer is used. Call wants to change the reference to this, but can’t, so call(obj2) doesn’t work on the arrow function, so print obj1 anyway.
-
Obj1.foo2.call (obj2)() is the first layer of the arrow function, and it wants to change this via.call(obj2), but it doesn’t work, and its outer scope is window, so it prints window, and the second layer is a normal function, This is the last call to the window, so it prints window as well.
-
Obj1.foo2 ().call(obj2) The first layer is an arrow function, the outer scope is window and prints out window, and the second layer is a normal function and uses.call(obj2) to change this, so prints out obj2.
conclusion
-
This, inside a normal or anonymous function, is the object on which the function is finally called
-
This inside the arrow function is the scope in which the arrow function is defined