The JavaScript this Keyword

JavaScript is the world's most popular programming language.
JavaScript is the programming language of the Web.
JavaScript is easy to learn.
This tutorial will teach you JavaScript from basic to advanced.
Post Reply
Guest

The JavaScript this Keyword

Post by Guest »

The JavaScript this Keyword



Example

const person = {
  firstName: "John",
  lastName : "Doe",
  id       : 5566,
  fullName : function() {
    return this.firstName + " " + this.lastName;
  }
};

Try it Yourself »


What is this?
In JavaScript, the this keyword refers to an object.
Which object depends on how this is being invoked (used or called).
The this keyword refers to different objects depending on how it is used:

In an object method, this refers to the object.
Alone, this refers to the global object.
In a function, this refers to the global object.
In a function, in strict mode, this is undefined.
In an event, this refers to the element that received the event.
Methods like call(), apply(),
and bind() can refer this to any object.


Note
this is not a variable. It is a keyword. You cannot change the value of this.





this in a Method
When used in an object method, this refers to the object.
In the example on top of this page, this refers to the person object.
Because the fullName method is a method of the person object.


fullName : function() {
  return this.firstName + " " + this.lastName;}

Try it Yourself »


this Alone
When used alone, this refers to the global object.
Because this is running in the global scope.
In a browser window the global object is [object Window]:

Example

let x = this;

Try it Yourself »

 In strict mode, when used alone, this also refers to the global object:

Example

"use strict";let x = this;

Try it Yourself »


this in a Function (Default)
In a function, the global object is the default binding for this.
In a browser window the global object is [object Window]:

Example

function myFunction() {
  return this;
}

Try it Yourself »








this in a Function (Strict)
JavaScript strict mode does not allow default binding.
So, when used in a function, in strict mode, this is undefined.

Example

"use strict";function myFunction() {
  return this;
}

Try it Yourself »


this in Event Handlers
In HTML event handlers, this refers to the HTML element that received the
event:

Example

<button onclick="this.style.display='none'">  Click to
Remove Me!</button>

Try it Yourself »



Object Method Binding
In these examples, this is the person object:

Example

const person = {
  firstName  : "John",
  lastName   : "Doe",
  id         : 5566,
  myFunction : function() {
    return this;  }
};

Try it Yourself »


Example

const person = {
  firstName: "John",
  lastName : "Doe",
  id       : 5566,
  fullName : function() {
    return this.firstName + " " +
this.lastName;  }
};

Try it Yourself »

i.e. this.firstName is the firstName property of this (the person object).

Explicit Function Binding
The call() and apply() methods are predefined JavaScript methods.
They can both be used to call an object method with another object as argument.

See Also:
The Function call() Method
The Function apply() Method
The Function bind() Method

The example below calls person1.fullName with person2 as an argument, this refers to person2,
even if fullName is a method of person1:

Example

const person1 = {
  fullName: function() {
    return this.firstName + " " + this.lastName;
  }}

const person2 = {
  firstName:"John",
  lastName: "Doe",
}

// Return "John Doe":
person1.fullName.call(person2);


Try it Yourself »



Function Borrowing
With the bind() method, an object can borrow a method from another object.
This example creates 2 objects (person and member).
The member object borrows the fullname method from the person object:

Example

const person = {
  firstName:"John",
  lastName: "Doe",
  fullName: function () {
    return this.firstName + " " + this.lastName;
  }
}

const member = {
  firstName:"Hege",
  lastName: "Nilsen",
}

let fullName = person.fullName.bind(member);

Try it Yourself »


This Precedence
To determine which object this refers to; use the following precedence of order.


PrecedenceObject
1bind()
2apply() and call()
3Object method
4Global scope

Is this in a function being called using bind()?
Is this in a function being called using apply()?
Is this in a function being called using call()?
Is this in an object function (method)?
Is this in a function in the global scope.













+1

Reference: https://www.w3schools.com/js/js_this.asp
Post Reply