DEV Community

Cover image for Higher-order Functions
kanaka raj
kanaka raj

Posted on

5 1

Higher-order Functions

A function takes another function has an argument (or) returns a function is called as Higher-Order functions
 function X(){
       console.log("Hey Luffy");               
      }

 function Y(X){
  x();
 }
 y()(); // Prints Hey Luffy 
Enter fullscreen mode Exit fullscreen mode

Here, function Y is accepting X() as an argument, Hence Y becomes a Higher-order function.

Understanding the purpose of Higher-order functions with an example

Consider the array of radius const radius = [3,4,5,1];
And the objective is to calculate the Area, Circumference and Diameter
Normal functions:

const calculateArea = function(radius){
const output = [];
   for(let i = 0; i < radius.length ; i++){
   output.push(Math.pi*radius[i]*radius[i]);
   }
return output;
}

const calculateCircuference = function(radius){
const output = [];
   for(let i = 0; i < radius.length ; i++){
   output.push(Math.pi*2*radius[i]);
   }
return output;
}

const calculateDiameter = function(radius){
const output = [];
   for(let i = 0; i < radius.length ; i++){
   output.push(2*radius[i]);
   }
return output;
}
Enter fullscreen mode Exit fullscreen mode

The above 3 functions work perfectly, but there's a problem.
can you spot the problem? If you spot it, we will try to solve the problem, else the problem is:

  • Repetitive code => There's a principle in software Engineering, DRY principle which stands for Don't repeat yourself. the above 3 functions have almost 90% of the same code, and what changes is the logic of Area, Circumference, Diameter.

Optimized Approach:
After Observing the functions, we are repeating the array declaration, iterating loop, returning array again and again. And the logic is the only thing which is changing.
and why don't we just extract the logic outside the function and writing it as an separate function.
Eg:

const area = function(radius){
return Math.pi*radius[i]*radius[i];
}
Enter fullscreen mode Exit fullscreen mode

Now let us write a generic function which the accepts the Array, and the logic function as argument, and just perform array initialization, loop iteration, logic function call, and return array.
Yeah, we are writing a Higher order function.

const calculate = function(radius, logic){
 const output = [];
   for(let i = 0; i < radius.length ; i++){
   output.push(logic(radius[i])); // every time the logic is called with new array value.
   }
return output;
}
Enter fullscreen mode Exit fullscreen mode

If we call the calculate function calculate(radius,area); it returns the array of Areas.

THE BEAUTY:
Lets see how amazing the calculate function is.
Now we need to calculate the circumference, diameter. we no longer need to copy paste the code. But we can just write the logic function circumference and diameter or any value you want to find.
just write the logic in a function and pass it to calculate function as a second argument.

const circumference = (radius){
return 2*Math.pi*radius;
}
const daimeter = (radius){
return 2*radius;
}
Enter fullscreen mode Exit fullscreen mode

just call the calculate function with these two passed as second argument. calculate(radius,circumference) calculate(radius,daimeter)

Conclusion:
Functional programming is huge in itself but as a small part of it say that "Think in smaller functions". Whenever you're giving a coding round Interview then try to write the code in Higher-order functions.

Thank you.

Heroku

Deploy with ease. Manage efficiently. Scale faster.

Leave the infrastructure headaches to us, while you focus on pushing boundaries, realizing your vision, and making a lasting impression on your users.

Get Started

Top comments (2)

Collapse
 
thorstenhirsch profile image
Thorsten Hirsch

Your indentation is worthy of discussion. 🤯

Collapse
 
kanakaraju profile image
kanaka raj

Thank you😁

5 Playwright CLI Flags That Will Transform Your Testing Workflow

  • 0:56 --last-failed
  • 2:34 --only-changed
  • 4:27 --repeat-each
  • 5:15 --forbid-only
  • 5:51 --ui --headed --workers 1

Learn how these powerful command-line options can save you time, strengthen your test suite, and streamline your Playwright testing experience. Click on any timestamp above to jump directly to that section in the tutorial!

👋 Kindness is contagious

Explore a trove of insights in this engaging article, celebrated within our welcoming DEV Community. Developers from every background are invited to join and enhance our shared wisdom.

A genuine "thank you" can truly uplift someone’s day. Feel free to express your gratitude in the comments below!

On DEV, our collective exchange of knowledge lightens the road ahead and strengthens our community bonds. Found something valuable here? A small thank you to the author can make a big difference.

Okay