Arrow Function in JS
data:image/s3,"s3://crabby-images/763b9/763b98ccdfb199cfdf1ebe899f482f40846c6cd2" alt="Kartikey Katyal"
An arrow function expression is a compact alternative to a traditional function expression, with some semantic differences and deliberate limitations in usage:
Arrow functions don't have their own bindings to
this
,arguments
, orsuper
, and should not be used as methods.Arrow functions cannot be used as constructors. Calling them with
new
throws aTypeError
. They also don't have access to thenew.target
keyword.Arrow functions cannot use
yield
within their body and cannot be created as generator functions.
Example of Arrow Function in JS
// Traditional anonymous function
(function (a, b) {
const chuck = 42;
return a + b + chuck;
});
// Arrow function
(a, b) => {
const chuck = 42;
return a + b + chuck;
};
Arrow Functions vs Regular Functions
Feature | Arrow Function | Regular Function |
Syntax | Concise, const fn = () => {} | More verbose, function fn() {} |
this Binding | Lexical (inherits this from surrounding scope) | Dynamic (this depends on how function is called) |
Hoisting | ❌ No hoisting (must be declared first) | ✅ Hoisted (can be used before declaration) |
Arguments Object | ❌ No arguments object | ✅ Has arguments object |
Usage | Best for callbacks, one-liners, and functional programming | Best for traditional function declarations |
Arrow functions do not have their own this
, instead, they inherit this
from the surrounding scope.
Regular Function (this
changes)
const person = {
name: "John",
greet: function() {
console.log(`Hello, my name is ${this.name}`);
}
};
person.greet(); // Output: Hello, my name is John
Arrow Function (this
is inherited
)
const person = {
name: "John",
greet: () => {
console.log(`Hello, my name is ${this.name}`);
}
};
person.greet(); // Output: Hello, my name is undefined (or empty)
Arrow Functions in Callbacks
Arrow functions are commonly used in callbacks because they are shorter and do not change this
.
Example: Array map()
with Regular Function
javascriptCopyEditconst numbers = [1, 2, 3, 4];
const squares = numbers.map(function(num) {
return num * num;
});
console.log(squares); // Output: [1, 4, 9, 16]
Example: Array map()
with Arrow Function
javascriptCopyEditconst numbers = [1, 2, 3, 4];
const squares = numbers.map(num => num * num);
console.log(squares); // Output: [1, 4, 9, 16]
Arrow Functions in setTimeout
javascriptCopyEditsetTimeout(() => {
console.log("This runs after 2 seconds");
}, 2000);
This is useful because setTimeout
runs in a different scope, and a regular function would have a different this
.
Arrow Function with arguments
Arrow functions do not have their own arguments
object, unlike regular functions.
Regular Function (Has arguments
)
javascriptCopyEditfunction showArgs() {
console.log(arguments);
}
showArgs(1, 2, 3); // Output: [1, 2, 3]
Arrow Function (No arguments
)
javascriptCopyEditconst showArgs = () => {
console.log(arguments);
};
showArgs(1, 2, 3); // ❌ Error: arguments is not defined
If you need arguments
, use the rest operator ...args
:
javascriptCopyEditconst showArgs = (...args) => console.log(args);
showArgs(1, 2, 3); // Output: [1, 2, 3]
When to Use Arrow Functions?
✅ Use Arrow Functions When:
You need a shorter syntax (e.g., for callbacks).
You want to avoid binding
this
manually.You're working with functional programming (
map()
,filter()
,reduce()
).
❌ Avoid Arrow Functions When:
You need function hoisting.
You require
this
to refer to the calling object (e.g., inside objects or classes).You need access to the
arguments
object.
Summary
Feature | Arrow Function (=> ) | Regular Function |
Short Syntax | ✅ Yes | ❌ No |
Hoisting | ❌ No | ✅ Yes |
Own this | ❌ No (lexical this ) | ✅ Yes |
Own arguments | ❌ No | ✅ Yes |
Use Cases | Callbacks, functional programming | Methods, constructors |
Subscribe to my newsletter
Read articles from Kartikey Katyal directly inside your inbox. Subscribe to the newsletter, and don't miss out.
Written by
data:image/s3,"s3://crabby-images/763b9/763b98ccdfb199cfdf1ebe899f482f40846c6cd2" alt="Kartikey Katyal"