When it comes to this, we often have a headache. In fact, we have clear rules! You’ll find it’s not as difficult as you think!
Common scenarios
- A normal function’s this: points to its caller, and if there is no caller, points to window by default.
- Arrow function this: refers to the object on which the arrow function is defined, not to the object on which the arrow function is used. By default, parent this is used.
- The direction of this is undefined at function definition, and only when the function is executed can it be determined who this refers to. In fact, this refers to the object that called it.
- The this in the constructor is bound to the object we’re new to: the default binding to point to.
About the weight
Bind has more weight than Call and apply!!
Highest weight: New!
The difference between the browser and Node is in the browser, pointing to window; In Node, point to Global. (In strict mode, point to undefined)
In three special cases, this will refer 100% to the window: IIFE
Supplement common methods of forming IIFE
- Functions cannot be called directly with parentheses.
- A function must be converted to a function expression before it can be called.
(function(){ alert(1); }) (); !function(){ alert(1); } (); +function(){ alert(1); } (); -function(){ alert(1); } (); ~function(){ alert(1); } ();Copy the code
Function passed in setTimeout function passed in setInterval
In strict mode, this holds the value of the object to which it was specified, so if no object is specified, this is undefined
Call, apply, bind
Change the function’s this pointer
- Call Apply directly after the change
fn.call(target, arg1, arg2)
fn.apply(target, [arg1, arg2])
Copy the code
- The difference between call and apply is reflected in the requirements for input parameters. The former simply passes in the object function’s incoming arguments one by one, while the latter expects the incoming arguments to be passed in as an array.
- Just change, not implement
fn.bind(target, arg1, arg2 )
Copy the code
It’s just important to note that with bind if you want to do it, you need to put in a call
fn.bind(target, arg1, arg2 )()
Copy the code