Blog/NotesConcept

Call Polyfill in JavaScript: Step by Step Explanation (For Interviews)

A brief description of the "call" method in JavaScript and a step-by-step explanation of how to create call Polyfill in JavaScript by understanding its internal implementation.

Intermediate

Anuj Sharma

Last Updated Jan 16, 2025


Advertisement

How does the call method work in JavaScript?

Call is the function's method and is available to all functions in Javascript. By default, all functions have their context. The Call method passes the dynamic context to the function so that the same function can be utilized with different contexts.

The call takes the context as the first parameter and then the function parameters can be passed in the comma-separated arguments

<function>.call(<context>, param1, param2, param3, ...paramN);

Examples

In this example, employee1 and employee2 are passed as a context followed by the function's arguments role and company in comma comma-separated fashion.

// function
function getEmployeeInfo (role, company) {
  console.log(
    `${this.firstName} ${this.lastName} works as ${role} in ${company}`
  );
};

// object 1
const employee1 = {
  firstName: 'Anuj',
  lastName: 'Sharma',
  age: '32',

  getAge: function() {
    console.log(`Employee age is ${this.age}`);
  }
};

// object 2
const employee2 = {
  firstName: 'Ajay',
  lastName: 'Singh',
  age: '28'
};

// Passing the employee1 context to the getEmployeeInfo
getEmployeeInfo.call(employee1, 'Engineering Manager', 'Dell');
// Output: Anuj Sharma works as Engineering Manager in Dell

// Passing the employee2 context to the getEmployeeInfo
getEmployeeInfo.call(employee2, 'Software Engineer', 'Microsoft');
// Output: Ajay Singh works as Software Engineer in Microsoft

employee1.getAge.call(employee2);
// Output: Employee age is 28

In the below example global this is passed as a context to the function

this.firstName = 'Vikas';
this.lastName = 'Kulkarni';

// function
function getEmployeeInfo (role, company) {
  console.log(
    `${this.firstName} ${this.lastName} works as ${role} in ${company}`
  );
};

getEmployeeInfo.call(this, 'Software Engineer 2', 'Zomato');
// Output: Vikas Kulkarni works as Software Engineer 2 in Zomato

Call Polyfill in JavaScript: Step by Step Explanation

Here is the step-by-step explanation of call polyfill.

It is important to note that the call method is a prototype method of the Function object in javascript, so customCall is created as part of the prototype which will override the call method and is defined as Function.prototype.customCall

Step 1: Capture the currentContext, this will be the context passed as the first parameter of the call function. In case nothing is passed currentContext gets the global context value, which is "window" in the browser & "global" in Nodejs env. globalThis will provide appropriate value as per the execution environment.

Step 2: Create a new Symbol key to avoid overriding any existing key in the currentContext (Nothing but an object).

Step 3: Assign the function's context ("this"), on which the call function is invoked. 

Step 4: Now, since the invoker function is part of the currentContext, It can access values from the current context. Now call the function and pass the arguments (comma-separated parameters got as part of the call).

Step 5: Delete the symbol key, to avoid pollution in the currentContext.

Step 6: Return the result that was part of the function execution as the final result.

Call Polyfill Implementation:

Function.prototype.customCall = function (context, ...args) {

  // Step 1: context is the first argument, if no argument is passed then the global window object is assigned
  let currentContext = context || globalThis;

  // Step 2: Symbol() ensures that the new method won't override existing methods of currentContext
  let newProp = Symbol();

  // Step 3: assigning this to newProp of currentContext
  currentContext[newProp] = this; 

  // Step 4: call the function with passed context
  let result = currentContext[newProp](...args);

  // Step 5: Delete the Symbol key, after execution of the function in step 4
  delete currentContext[newProp];

  // Step 6: result returned by function
  return result;
};

Further reading 

Other Function Method Polyfills

👉 Bind Polyfill in JavaScript: Step by Step Explanation

👉 Apply polyfill in JavaScript: Step by Step Explanation


Share this post now:

Advertisement

💬 Comments (0)

Login to comment

Advertisement

Flaunt You Expertise/Knowledge & Help your Peers

Sharing your knowledge will strengthen your expertise on topic. Consider writing a quick Blog/Notes to help frontend folks to ace Frontend Interviews.

Advertisement


Other Related Blogs

20+ Frontend Machine Coding Interview Questions (JS + React)

Anuj Sharma

Last Updated Jun 27, 2025

A detailed list of 20+ most asked Frontend Machine Coding Interview Questions and resources both in JavaScript & React. Also covers expected functional/Non-functional requirements in this Interview.

Master Hoisting in JavaScript with 5 Examples

Alok Kumar Giri

Last Updated Jun 2, 2025

Code snippet examples which will help to grasp the concept of Hoisting in JavaScript, with solutions to understand how it works behind the scene.

Best Cheat Sheet for Frontend Machine Coding Interview Round

Anuj Sharma

Last Updated Jun 13, 2025

A comprehensive cheat sheet for the Frontend Machine Coding Interview Round, which helps to revise all the important machine coding & UI design concepts before the interview.

HTTP/2 vs HTTP/1.1: What's the Key Difference?

Anuj Sharma

Last Updated Jan 29, 2025

Understand the difference between HTTP/2 vs HTTP/1.1 based on the various parameters, which helps to understand the improvement areas of HTTP/2 over HTTP 1.1

Part 1: From Zero to Published — How I Built and Published My First React NPM Package

Akash Deep Chitransh

Last Updated May 26, 2025

Learn how to build and publish your own NPM package with Rollup, testing, and troubleshooting. Stay tuned for part 2: building a React state management library!

Understand JavaScript Date Object with Examples (for JavaScript Interviews)

Anuj Sharma

Last Updated Jan 9, 2025

Go through different ways to display dates using javascript date object. It covers examples of date object usage to understand the main concepts of javascript date object.

FrontendGeek
FrontendGeek

© 2024 FrontendGeek. All rights reserved