With the advent of the big front end era, in the process of product development, the front end takes up more and more business and interaction. The traditional old man with JQuery is a shuttle to cope with today’s heavy interactive pages. Hence Angular, React, Vue, and other modern frameworks.

However, there are also a lot of new knowledge and new terms, such as MVC, MVVM and Flux, which make many students confused. At this time to see others talking about functional programming, is a face of confusion.

Most of us have heard of object-oriented programming, procedural programming, but what is functional programming? What are the application scenarios in our front-end development? I hold this doubt, the preliminary study. (This article is just a study, nothing to do).

Functional programming

define

Functional Programming (FP) is defined by Wikipedia as:

A programming paradigm that treats computer operations as mathematical functions and avoids the use of program states and mutable objects. The most important foundation of functional programming languages is lambda calculus. And the function of the lambda calculus can accept functions as inputs (arguments) and outputs (outgoing values). Compared with imperative programming, functional programming emphasizes the results of program execution rather than the process of execution, advocating the use of several simple execution units to make the results of calculation gradually, and the derivation of complex operations layer by layer, rather than designing a complex execution process.

So let me try to understand this definition, which is like, when I’m typing code, I’m going to write the procedure logic as a function, define the input parameters, and only care about the output. And you can take functions as input and output. Feel like ordinary write JS, is such!

features

The definition and characteristics of FP are abundant on the web. Encyclopedias, blogs, and some teachers’ websites all have similar descriptions. To make it easier to read, I’ve listed a few features that seem important, along with my first understanding.

  1. The function is a first-class citizen. It means that a function can be an input or output of any other function, just like any other variable. Well, callbacks are typical.

  2. Immutable. You can’t use var and let. With this requirement, I seem to have a little trouble writing code.

  3. Pure functions. It’s a function that has no side effects. This is easy to understand, just don’t change the variables outside the function.

  4. Reference transparency. This is easy to understand, which means that the same input must be the same output. The inside of a function does not depend on external state, such as some global variables.

  5. Lazy calculation. A variable bound to an expression is evaluated not when it is declared, but when it is actually used.

There are also some derivative features, such as Collicalization and composition, which are not explained in a few words, but can be further explored by students who are interested.

FP in JavaScript application

React is the classic FP. Unlike MVVM frameworks like Vue, it is simply a View layer. ReactView = render(data) it only cares about your input and finally returns the corresponding view to you. So you can’t change the state of the parent in the React component, and there’s no bi-directional binding to the DOM.

This is the application on the framework, so what are the applications that we use when we write JavaScript? In other words, when we write JS in general, we would be better off using FP.

Let’s start with the most common ones, like a typical array of operations:



// Select the names of people older than 15 from users
const users = [
  {
    age: 10.name: 'Joe'}, {age: 20.name: 'bill'
  }, {
    age: 30.name: 'Cathy'}];/ / process type
const names = [];
for (let i = 0; i < users.length; i++){if (users[i].age > 15) { names.push(users[i].name); }}/ / function type
const names = users.filter(u= > u.age > 15).map(u= > u.name);
Copy the code

Well, the code is a lot leaner, but it seems to add more overhead. If it’s really big data, a lot of sifting, it’s going to loop multiple times.

I have to think about this lazy calculation. By lazy evaluation, you should actually filter the age and get the name array only when the result is finally returned.

JavaScript arrays, however, do not support lazy evaluation. At this point, we need to go to some tool libraries like Lodash. Take a look at its documentation for an example: _.chain.

It’s not as good as changing multiple lines of code into one line. That’s ridiculous, and there’s a performance overhead, and then you tell me about a tool library…

This may sound reasonable, but the drawback of the for loop is that it produces variable I, which is uncontrollable. If the business logic is complex, who knows when it will loop and if I will change, then the loop will fail?

Let’s look at another scenario where we interact with the DOM: if the page has a button, we need to figure out how many times the user clicked it, but repeated clicks within a second don’t count. The traditional way of writing it is this.



var count = 0;
var rate = 1000;
var lastClick = Date.now() - rate;
var button = document.querySelector('button');
button.addEventListener('click', () = > {if (Date.now() - lastClick >= rate) {
    console.log(`Clicked ${++count} times`);
    lastClick = Date.now(); }});Copy the code

Yes, no problem at all. But there are a lot more states, count, rate, lastClick, and you have to compare and compare. So what happens if YOU use FP?

I’m sorry… Can’t write… Unless very strong programming ability, their own encapsulation method to deal with. So in this case, we can go to the tool – rx.js, the above example is referenced in RXJS, let’s see how it is handled elegantly.



var button = document.querySelector('button');
Rx.Observable.fromEvent(button, 'click')
  .throttleTime(1000) // Events are emitted every 1000 milliseconds
  .scan(count= > count + 1.0) // Evaluate, default is 0
  .subscribe(count= > console.log(`Clicked ${count} times`)); // Subscribe results, output valuesCopy the code

God’s work! You don’t have to manage state anymore, you don’t have to declare a bunch of variables, you don’t have to modify, you don’t have to judge, it’s perfect.

Normally we have a lot of asynchronous operations that need to update the DOM, such as search behavior: the user continuously enters the query value, and if the pause is half a second, the search will be executed, and if the search is repeated and multiple requests are made, only the final search result will be returned.

Close your eyes and think about how you did it before. Anyway, I’m setting the start time, the end time, the last time, etc. Tedious and uncontrollable.

When we implement with the thought of FP, we will find ways to reduce variables, to elegant programs. The most common way to do this is to use someone else’s library. Of course, some simple scenes can also be realized by themselves, the most important thing is to have this awareness.

In fact, we usually write some FP, we just don’t realize it, or not write it well. Like closures, many people don’t understand the concept of closures, but they’ve actually written a lot of closure code. Closures themselves are an application of functional programming.

Since MY own understanding is not deep, can not elaborate on the application of FP, if you are interested, you can learn more about it.

Advantages and disadvantages of FP in JavaScript

Summarize the advantages and disadvantages of FP, so that we can better choose whether to use FP in the actual development.

advantage

  1. Better management status. Because it’s all about statelessness, or less states. In normal DOM development, because the visual rendering of the DOM depends on state changes, it is inevitable that there will be a lot of states, and different components may depend on each other. Programming with FP minimizes these unknowns, optimizes code, and reduces error.

  2. Easier reuse. The extreme of FP code is that every line of code is a function, but we don’t need to be that extreme. We tried to implement the process logic as a purer function, fixed input -> fixed output, no other external variables, and no side effects. This allows code to be reused without any consideration of its internal implementation or external impact.

  3. A more elegant combination. In the grand scheme of things, a web page is made up of components. On a smaller scale, a function may be composed of several smaller functions. Refer to the second point above. Greater reusability leads to greater composability.

  4. Hidden benefits. Reduce code and improve maintainability.

disadvantage

  1. JavaScript is not a strictly functional language, and many of the features of functional programming are not. For example, the lazy chain evaluation of an array. To implement it, you have to go to a tool library, or encapsulate your own implementation, raising the cost of writing code.

  2. It does not improve performance compared to procedural. In some cases, if you force FP to be written, performance may also be reduced because there are no intermediate variables.

  3. The code is hard to read. This varies from person to person, just because of the size. This code may seem obvious to those who are particularly familiar with FP. The uninitiated, confronted with written arcane code, are instantly stunned by stacks of lambda calculus and anonymous functions () => () => (). It takes half an hour in your head to understand the code.

  4. Learning costs are high. On the one hand, it inherits from the previous point. On the other hand, a lot of front-end coders, because of their relative dislike of some of the underlying abstract programming languages, have entered the front-end hole, and now you have them jumping into FP, they are confused.

conclusion

Personally, FP is good. For development, it can really optimize our code, and once we get familiar with it, it can also improve our programming efficiency. For programming itself, it can also expand our thinking beyond procedural programming code.

In the preparation of JS, you can try to use FP thinking, such as immutable, pure function, lazy evaluation. But it doesn’t have to be dogmatic to follow functional programming, it has to be something. For example, take a look at one of Zhihu’s answers: the portal.

Well, it’s not easy to be a page boy. But don’t want to be a big cow page boy is not a good page boy!

reference

  1. Functional programming tutorial – Ruan Yifeng

  2. Functional programming language – Wikipedia

  3. Where is the real use of front-end development JS functional programming? – Zhihu answers