Detailed explanation of the this pointing problem in JavaScript

Detailed explanation of the this pointing problem in JavaScript

Summarize

  • Global environment ➡️ window
  • Normal function ➡️ window or undefined
  • Constructor ➡️ Constructed instance
  • Arrow function ➡️ this in the outer scope when defined
  • Object methods ➡️ The object
  • call(), apply(), bind() ➡️ The first parameter

Global Environment

Regardless of strict mode, this refers to the window object.

console.log(this === window) // true
// Strict mode 'use strict'
console.log(this === window) // true

Ordinary functions

  1. Normal Mode
    • this refers to the window object
    • function test() {
        return this === window
      }
      
      console.log(test()) // true
      
  2. Strict Mode
    • this value is undefined
    • // Strict mode 'use strict'
      
      function test() {
        return this === undefined
      }
      
      console.log(test()) // true
      

Constructor

When a function is used as a constructor, this points to the constructed instance.

function Test() {
  this.number = 1
}

let test1 = new Test()

console.log(test1.number) // 1

Arrow Functions

When the function is an arrow function, this refers to the this value in the previous scope when the function is defined.

let test = () => {
  return this === window
}

console.log(test()) // true
let obj = {
  number: 1
}

function foo() {
  return () => {
    return this.number
  }
}

let test = foo.call(obj)

console.log(test()) // 1

Object methods

When a function is used as a method of an object, this refers to the object.

let obj = {
  number: 1,
  getNumber() {
    return this.number
  }
}

console.log(obj.getNumber()) // 1

call(), apply(), bind()

  • When calling the call() or apply() method of a function, the this of the function points to the first parameter passed in.
  • When the bind() method of a function is called, the this of the returned new function points to the first parameter passed in.
let obj = {
  number: 1
}

function test(num) {
  return this.number + num
}

console.log(test.call(obj, 1)) // 2

console.log(test.apply(obj, [2])) // 3

let foo = test.bind(obj, 3)
console.log(foo()) // 4

This is the end of this article about the detailed case of this pointing problem in JavaScript. For more related content about this pointing problem in JavaScript, please search for previous articles on 123WORDPRESS.COM or continue to browse the related articles below. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • JavaScript basics of this pointing
  • Detailed explanation of this pointing in JS arrow function
  • Detailed explanation of this reference and custom properties in JavaScript
  • Detailed explanation of function classification and examples of this pointing in Javascript
  • Detailed explanation of this pointing problem in JavaScript function
  • Detailed explanation of the this pointing problem of JavaScript prototype objects

<<:  How to install elasticsearch and kibana in docker

>>:  The difference between distinct and group by in MySQL

Recommend

How to add and delete unique indexes for fields in MySQL

1. Add PRIMARY KEY (primary key index) mysql>A...

React nested component construction order

Table of contents In the React official website, ...

Detailed explanation of the usage of compose function and pipe function in JS

Table of contents compose function Array.prototyp...

Solution to the problem that Docker container cannot be stopped or killed

Docker version 1.13.1 Problem Process A MySQL con...

React error boundary component processing

This is the content of React 16. It is not the la...

Analyze the compilation and burning of Linux kernel and device tree

Table of contents 1. Prepare materials 2. Downloa...

How to find identical files in Linux

As the computer is used, a lot of garbage will be...

Summary of pitfalls in virtualbox centos7 nat+host-only networking

Table of contents 1. Problem Background 2. What a...

Understand the principles of MySQL persistence and rollback in one article

Table of contents redo log Why do we need to upda...

How to use lodop print control in Vue to achieve browser compatible printing

Preface This control will have a watermark at the...

Some ways to solve the problem of Jenkins integrated docker plugin

Table of contents background Question 1 Error 2 E...

How to expand Linux swap memory

Swap memory mainly means that when the physical m...