Sign In Start Free Trial
Account

Add to playlist

Create a Playlist

Modal Close icon
You need to login to use this feature.
  • Mastering JavaScript Functional Programming
  • Toc
  • feedback
Mastering JavaScript Functional Programming

Mastering JavaScript Functional Programming

By : Federico Kereki
4.2 (6)
close
Mastering JavaScript Functional Programming

Mastering JavaScript Functional Programming

4.2 (6)
By: Federico Kereki

Overview of this book

Functional programming is a paradigm for developing software with better performance. It helps you write concise and testable code. To help you take your programming skills to the next level, this comprehensive book will assist you in harnessing the capabilities of functional programming with JavaScript and writing highly maintainable and testable web and server apps using functional JavaScript. This second edition is updated and improved to cover features such as transducers, lenses, prisms and various other concepts to help you write efficient programs. By focusing on functional programming, you’ll not only start to write but also to test pure functions, and reduce side effects. The book also specifically allows you to discover techniques for simplifying code and applying recursion for loopless coding. Gradually, you’ll understand how to achieve immutability, implement design patterns, and work with data types for your application, before going on to learn functional reactive programming to handle complex events in your app. Finally, the book will take you through the design patterns that are relevant to functional programming. By the end of this book, you’ll have developed your JavaScript skills and have gained knowledge of the essential functional programming techniques to program effectively.
Table of Contents (17 chapters)
close
1
Technical Requirements
14
Bibliography

Chapter 7, Transforming Functions – Currying and Partial Application

7.1. Sum as you willThe following sumMany() function does the job:

const sumMany = total => number =>
number === undefined ? total : sumMany(total + number);

sumMany(2)(2)(9)(6)(0)(-3)(); // 16

7.2. Working stylishly: We can do currying by hand for applyStyle():

const applyStyle = style => string => `<${style}>${string}</${style}>`;

7.3. Currying by prototype: Basically, we are just transforming the curryByBind() version so that it uses this:

Function.prototype.curry = function() {
return this.length === 0 ? this() : p => this.bind(this, p).curry();
};

You could work in a similar fashion and provide a partial() method instead.

7.4. Uncurrying the currying: We can work in a similar fashion to what we did in curryByEval():

const uncurryByEval = (fn, len) =>
...
bookmark search playlist download font-size

Change the font size

margin-width

Change margin width

day-mode

Change background colour

Close icon Search
Country selected

Close icon Your notes and bookmarks

Delete Bookmark

Modal Close icon
Are you sure you want to delete it?
Cancel
Yes, Delete