DEV Community

Tom Hoadley
Tom Hoadley

Posted on • Edited on

Functional Programming Basics Before You Learn React and Redux - The What - Part 1

This is a two part series on the functional programming basics you should know before learning React and Redux. Click here for part 2.


React and Redux are two of the most popular frameworks in the modern JavaScript ecosystem. React is used to build an applications front end and redux is used to manage the data in the back end. They are used together to build fast, scalable, maintainable applications.

This series of articles will give you an understanding of functional programming to serve as a foundation for your React and Redux knowledge. You will learn the what and how of functional programming in JavaScript, and be provided with transferable skills for other frameworks and languages as well.

The first article in the series simplifies the concepts of functional programming and by the end of the article, the entry barrier to learning React and Redux will hopefully seem a little smaller.

What is functional programming?

Similar to way you can choose to write a formal or informal style email, you can write different styles of code. There are a few different styles (aka paradigms) including; structured programming, object oriented programming and functional programming.

Believe it or not, these patterns have essentially been unchanged since Alan Turing wrote the first line of code on an electronic computer. Since then, mathematician Alfonso Church built on the work of Turing and introduced the Lambda Calculus in 1936, which then provided the backbone for John McCarthy’s LISP language in 1958, the first functional programming language.

This is reassuring, because despite the constant wave of new languages, frameworks and tools you see on a daily basis, functional programming concepts have persisted.

You may have noticed senior engineers seem to pick up new languages with ease. That’s because they have understood these core, unchanging concepts and can spot the underlying patterns of functional programming.

Why functional programming?

So what’s so great about functional programming and why did the React team choose it? Well, if you were to write an application that followed all of the functional principles your code would be,

  • Concise
  • Maintainable
  • Easier to debug
  • Testable
  • Readable
  • Reusable

You may not be as concerned about these benefits for a small personal application such as a to-do app but if you were working on large scale applications for a multi-million pound company, they are critical.

Functional programming concepts

Before introducing the concepts, its worth noting that there is no such thing as the perfect application or developer. Software engineering is as much an art as it is a science. Functional programming does not provide all the answers in a nice neat FAQ. You need to work hard to understand the concepts and use your best judgement on how and where they can be applied.

Secondly, the term ‘state’ is used in the below text. State refers to all the parts that change in an application. More simply, it’s your apps data. For example, in an online library application, the state could contain book titles, authors, if the user is a member, if the user has filled out a form on the website, etc. Knowing these two things we can begin to answer, what are the concepts of functional programming?

Functional programming says you should avoid the following

  • Avoid changing state (aka avoid mutations, aka immutability). This sounds strange at first because obviously things need to change in our app… The trick is, you need to be making copies of the state and editing the copy, rather than editing the original state. As an example, if you had an array of team members and wanted to add someone new, instead of editing the current array you should copy it and edit that. This may also be written as ‘you should transform your state’.
  • Avoid functions that change the ‘outside world’ (aka avoid side effects ). Again, this sounds strange but it’s similar to the above in that your functions should only copy and edit the input, rather than editing the original input. Some times side effects are required, for example, logging to console, writing to the screen, triggering an external process, writing to a file, etc, but where ever possible you should not be ‘editing’ the outside world, you should be ‘adding’ to it. Anytime you do need side effects, you should separate and isolate the actions from the rest of your application as much as possible.
  • The state in your application should never be ‘shared’ (aka avoid sharing state). For state to not be ‘shared’, it means that every time you need to ‘change it’ you should duplicate it and edit the duplicate, thus state is never ‘shared’ as such.

Functional programming says you should do the following

  • Writing functions that are predictable, only do one thing and do not change the ‘environment’ around it (aka write pure functions ). They have no ‘side effects’ and given the same input, they always return the same output.
  • Combine smaller functions into bigger functions that build a full application (aka be thoughtful about your function composition). This helps us achieve those desired application characteristics we mentioned at the start of the post. There are a number of tools that help us compose our functions in JavaScript which are outlined in the next post in the series.
  • You should write code that displays ‘what’ should happen rather than ‘how’ it should happen (aka write declarative code). An example of this would be choosing to use the map function, instead of a for loop, because the map function is a more concise version of a loop.

From the above, we can see that we are trying to avoid mutations, side effects and sharing state by writing pure functions. We are also being thoughtful with our function composition and writing declaratively. State management libraries such as redux provide a framework to achieve this in your applications, but before learning those you should know how to write it without their use.

To summarise we can understand the concepts as follows,

  • Avoid mutations
  • Avoid side effects
  • Avoid sharing state
  • Use pure functions
  • Be thoughtful about function composition.
  • Write declarative code

The second part of this series of functional programming will answer how exactly you can implement functional programming concepts with JavaScript.

--

Make sure to follow me on dev.to or twitter for more tutorials and articles to help with your journey into software engineering.

Top comments (5)

Collapse
 
monfernape profile image
Usman Khalil

It may not be the best read for a beginner but I thoroughly enjoyed it

Collapse
 
thomas_hoadley profile image
Tom Hoadley • Edited

Really glad you enjoyed it Usman! And thanks very much for the input, I've taken it into consideration and reworded the intro and title ever so slightly.

I think it's really going to help people who already have some idea of what React and Redux are and want to supplement their learning by understanding functional programming!

Collapse
 
pathakpratik profile image
Pratik Pathak

Waiting for the next part...

Collapse
 
thomas_hoadley profile image
Tom Hoadley

Fear not Pratik, the second in the series will be coming imminently!

Collapse
 
tarekarar profile image
TarekArar

redux is used to manage the data in the back end? Isn't used to manage global application state?