this keywordWhich object calls the function, and which object does this in the function point to? **Strict mode:** In the global environment, this refers to undefined **Non-strict mode: **In the global environment, this refers to window Globally defined functions are called directly, this => window function fn(){ console.log(this); // At this point this points to window } fn(); // Equivalent to window.fn() Function call inside an object, this => caller var obj = { fn:function(){ console.log(this); } } obj.fn(); // At this time this points to obj Timer processing function, this => window setTimeout(function(){ console.log(this); },0) // At this time, this in the timer processing function points to window Event handling function, this => event source div.onclick = function(){ console.log(this); } //When you click on div, this points to div Self-invoking function, this => window (function () { console.log(this) })() // At this point this points to window Change this to point toWhat we just talked about are the this pointers in the basic function calling methods. We also have three ways to ignore the this pointer of the function itself and point it to other places. These three methods are call / apply / bind, which are methods that forcibly change the pointer of this.
call Syntax: fn.call(where this points to in the fn function body, arg1, arg2, ...); Function: Call the bound function fn, specify its this pointer and pass parameters parameter:
Use the call method without passing parameters var num = 666; function fn() { console.log('num = ', this.num); } fn.call(); // num = 666 Use the call method to specify this var name = 'Rose'; var obj = {name:'Jack'}; function fn(){ console.log(this.name); } fn(); // Rose fn.call(); // Rose fn.call(obj); // jack Use the call method to specify this and pass parameters var name = 'Rack'; var obj = {name:'Jack'}; function fn(a,b){ console.log(this,a,b); } fn(1,2); // window 1 2 fn.call(obj,1,2); // obj 1 2 fn(1,3); // window 1 3 apply The apply method accepts an array containing multiple parameters. Syntax: fn.apply(where this points to in the fn function body, [arg1, arg2, ...]); Function: Call the bound function fn, specify its this pointer and pass parameters parameter:
var obj = {name:'jack'}; function fn(a,b){ console.log(this,a,b); } fn(1,2); // window 1 2 fn.apply(obj,[1,2]); // obj 1 2 Merging arrays using apply Use push to append elements to an array. If the argument is an array, it will add the array as a single element instead of adding each element in the array, so we end up with an array within an array. var arr1 = [1,2]; var arr2 = [3,4]; arr1.push(arr2); console.log(arr1); // [1,2,[3,4]] Although concat can merge arrays, it does not add elements to an existing array, but creates and returns a new array. var arr1 = [1,2]; var arr2 = [3,4]; var arr3 = arr1.concat(arr2); console.log(arr1); // [1,2] console.log(arr3); // [1,2,3,4] What if we want to append elements to an existing array? cycle? No! This is where apply comes in handy var arr1 = [1,2]; var arr2 = [3,4]; arr1.push.apply(arr1,arr2); console.log(arr1); // [1,2,3,4] Using apply with built-in functions /* Find the largest/smallest number in the array*/ var numbers = [5, 6, 2, 3, 7]; var max = Math.max(numbers) var min = Math.min(numbers) console.log(min,max); // NaN NaN var max = Math.max.apply(null, numbers); /* Basically equivalent to Math.max(numbers[0], ...) or Math.max(5, 6, ..) */ var min = Math.min.apply(null, numbers); console.log(min,max); // 2 7 bind Syntax: fn.bind(the pointer of this in the fn function body, arg1, arg2, ...); Function: Create a new bound function, specify its this pointer and pass parameters, it must be called before it will be executed parameter:
var obj = {name:'jack'}; function fn(a,b){ console.log(this,a,b); } fn(1,2); // window 1 2 fn.bind(obj,1,2); // Not called and not executed fn.bind(obj,1,3)() // obj 1 3 var newFn = fn.bind(obj,3,4); newFn(); // obj 1 4 newFn(5,6); // obj 3 4 SummarizeThis is the end of this article about the this pointing problem in JavaScript functions. For more relevant JavaScript function this pointing content, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future! You may also be interested in:
|
<<: Detailed tutorial on installing Protobuf 3 on Ubuntu
Apache Tika is a library for file type detection ...
Introduction Use simple jQuery+CSS to create a cus...
Preface Hello everyone, this is the CSS wizard - ...
Menu bar example 1: Copy code The code is as foll...
Let's first understand a wave of concepts, wh...
This is a pretty cool feature that makes web page...
Preface In the case of primary key conflict or un...
The local environment is Windows 10 + WSL2 (Ubunt...
Table of contents Preface Code Implementation Ide...
1. Favicon.cc To create ico icon websites online,...
It is standard for websites to enable SSL nowaday...
This article mainly introduces how to add floatin...
This article describes how to install opencv with...
Create a table CREATE TABLE `map` ( `id` int(11) ...
1.1 What is MySQL multi-instance? Simply put, MyS...