Hello everyone👋🏻, In this article, we are going to discuss ‘this’ keyword in Javascript(JS). The this keyword is one of the most widely used keywords. It can seem complex & difficult to understand at first, but once you start using the “this” keyword, everything will become straightforward and easy.

The “this” keyword in JavaScript(JS) is a reserved keyword meant to help you target certain objects in JavaScript. To be more specific, it’s meant to help you target the current object. 

The main purpose of this keyword is to give methods access to their objects to perform some actions and to make our code reusable by allowing us to execute the same code for multiple objects.

Let’s understand it better in detail by taking an example.

What is the ‘this’ keyword?

If we used the ‘this’ keyword in the function, then it means it points to an object to which it is bound. In other words, this references the object currently calling the function. The value of this is the window object.

For example,

In the above code, this references the counter object. The show() function is the property of the counter object. Therefore, inside the show() function, this references the counter object.

Types of Binding in Javascript

There are various ways that can be used to know which object is referred to by this keyword.

1. Default Binding

In this context, variables are declared outside the function. Here, this keyword refers to the window object.

This rule, however, doesn’t hold if getName() were to be defined in strict mode:

When set in strict mode, this reference is set to undefined.

2. Implicit Binding

It is applied when you call a function using the object and dot notation. In this case, this keyword points out the object, that is used to call the function.

We can also call the function using the nested objects. See the below example:

3. Explicit Binding

We saw in the Implicit Binding, that this is implicitly bound to the object the function is being called from. But in Explicit, we pressurized the function to use the particular object as its context.

We can achieve this by using two methods call() & apply(). These two utility methods are available to all the functions in Javascript.

So, you have to invoke the call(), apply() on that function, and pass the context object as the parameter.

🔖Note: If you pass the same function around multiple times to new variables. On every call, it will use the same context because it has been locked (explicitly bound) to that object. This is called Hard Binding.

4. Constructor Call Binding

When you use the new keyword to create an instance of a function object, you use the function as a constructor. The following things can happen:

☑️Creation of a new object.

☑️A newly constructed object is linked to the function that constructed it.

☑️The constructed object is set as this binding to that function call.

Understand it better with the example:


So, to wrap up all the points:

1. this keyword, when used in a function, binds that function to a context object.

2. There are four types of binding: Default, Implicit, Explicit, and Constructor call (new).

3. The behavior of this keyword changes between strict and non-strict modes.

These rules will help you easily catch the context for this reference.

So, we learned about this keyword in Javascript(JS), and how you can use it to refer to any object in multiple ways. With this, we have come to the end of our article. I hope you understood what is this keyword and how they are used.

For more such content keep following and subscribing to this page. Please reach out to us in the comment section or drop us an email, and we will surely help you in clearing doubts.

Thanks 😉 Happy Learning.

Also, read

AWS Solutions Architect Certification Preparation – (SAA-C02) Explain this keyword in JS with examples What are the events in Javascript? How does the event function work? [7] Advanced and Useful Linux – Ubuntu Commands How to revert or undo last commit in Git? Explain For, While, Do-While Loops in JS and more Setup AWS CLI on MAC, Windows, and Linux