DEV Community

Bilal Niaz
Bilal Niaz

Posted on

3

Differences Between Arrow and Regular Functions

The fat arrow function is another name for an arrow function. It's a new feature in ES6 that allows you to write function expressions in a more compact manner. Regular JavaScript functions and arrow functions are similar in operation, although there are several distinctions. Let's have a look at the differences:

  1. Syntax
  2. Arguments binding
  3. Use of this keyword
  4. Using a new keyword
  • Syntax By writing a few lines of code using arrow functions, a programmer can get the same result as ordinary functions.

Image description

  • Arguments binding arguments object inside the regular functions contains the list of arguments.

Image description
The arrow function, on the opposite, doesn’t define arguments i.e. they do not have arguments binding.

Image description

  • Use of this keyword This value is dynamic inside a standard JavaScript function. Because of the dynamic context, the value of this variable changes depending on how the function is called.

Image description
Because an arrow function lacks its own "this" keyword, the behaviour of this inside an arrow function differs significantly from that of an ordinary function.
This inside an arrow function has the same value throughout its lifetime and is always linked to the value of this in the nearest non-arrow parent function, which means This value inside an arrow function always equals this value from the outer function, regardless of how or where it is executed.

Image description

  • Using a new keyword Regular functions can be built and called. The new keyword can be used to call them.

Image description
But, the arrow functions are only callable and not constructible, i.e., arrow functions can never be used as constructor functions.

Image description
summary
Inside a normal function, this value is dynamic and changes depending on how the function is called. However, the inner arrow function is lexically bound and equals the outer function. This a value is always bound to the class instance using fat arrow methods.

Image of Wix Studio

2025: Your year to build apps that sell

Dive into hands-on resources and actionable strategies designed to help you build and sell apps on the Wix App Market.

Get started

Top comments (0)

Imagine monitoring actually built for developers

Billboard image

Join Vercel, CrowdStrike, and thousands of other teams that trust Checkly to streamline monitor creation and configuration with Monitoring as Code.

Start Monitoring

πŸ‘‹ Kindness is contagious

Dive into an ocean of knowledge with this thought-provoking post, revered deeply within the supportive DEV Community. Developers of all levels are welcome to join and enhance our collective intelligence.

Saying a simple "thank you" can brighten someone's day. Share your gratitude in the comments below!

On DEV, sharing ideas eases our path and fortifies our community connections. Found this helpful? Sending a quick thanks to the author can be profoundly valued.

Okay