10 JavaScript Concepts You Need to Master React (+ Cheatsheet)

Reed Barger
Jan 13 · 8 min read

Aside from a few unique features that it has, such as JSX, React is at it’s core plain JavaScript.

That means we can always use the best and most appropriate parts of JavaScript to enhance and better develop our React applications.

In short, the better you become at JavaScript the better you’ll be at React.

To accelerate your path to becoming a confident React developer, I’ve put together what I believe are the 10 most essential JavaScript concepts that you should know to become more effective with React.

These concepts can be found in virtually every serious React app, whether you are building the app yourself or reading the code for it.

The article comes with an entire PDF cheatsheet featuring all of the code in this article.

You can download that for free right here.

Here are some added benefits of grabbing the cheatsheet:

  • ✓ Quick reference guide to review however and whenever
  • ✓ Copyable code snippets for easy reuse and reference
  • ✓ Features mini React app to show how these concepts work together in a practical example

let and const variables

Why use let and const in JavaScript?

The let and const keywords give us create more precise, predictable variables than those declared with var.

let and const fix annoying problems of the var keyword such as hoisting

  • Hoisting is a phenomenon when variables can be used before they are created. It’s a pretty strange behavior and this can cause subtle bugs in our code.

let and const have block scoping

  • Variables declared with let and const within curly braces, that let / const variable only exists within that code block and not outside it.
  • Block scoping results in more predictable, less-error prone code by variables conflicting with each other less often

let keyword is used for variables that need to be reassigned after being declared; const for variables that are not reassigned

How are let / const used in React?

let / const are the preferred keywords for declaring any kind of variable in React due to the added predictability of how they function

  • Simply put, variables that should be reassigned are declared with let; variables that should not be reassigned and should only reference one thing are declared with const

const is used to declare components as well when combined with arrow functions (we’ll cover arrow functions later)

  • const is used for creating components because they will never to change to something else

Template Literals

Why use template literals in JavaScript?

Template literals are much more powerful, dynamic strings than basic JavaScript strings using single or double quotes

  • Interpolating or inserting values into strings is much easier; uses the ${} syntax to insert valid JS expressions
  • No need to use the + operator to concatenate or combine strings as before
  • Easier to write multiline strings — no need to write new lines with the newline character (\n) or carriage return (\r)
  • Can use nested quotes (with single or double quotes) within template literals strings without errors

How are template literals used in React?

Template literals are used for string interpolation as well as things like dynamically setting the string value of props of components or attributes of elements.

  • Template literals are great for dynamically calculating the styles of elements based on different conditions, such as the example below:

Arrow Functions

Why use arrow functions in JavaScript?

Arrow functions allow us to write functions in a shorter syntax, resulting in less boilerplate code for our functions

  • Allows us to replace the return keyword and the function body (curly braces) with a fat arrow syntax: =>
  • It also makes working with objects and classes easier due to how it handles the this keyword.

Arrow functions come with 3 shorthands, meaning even shorter functions

  • The parentheses around parameters can be removed if there is just one
  • Curly braces for function body can be removed entirely
  • No need for the return keyword; arrow functions have an implicit return (they return by default without curly braces)

How are arrow functions used in React?

Arrow functions are used anywhere we can create a function in JavaScript

They are used most often to create function components as well as for higher-order array methods like .map() or .filter()

Powerful Array Methods (.map(), .filter(), .reduce(), etc.)

Why use powerful array methods in JavaScript?

As compared to using a for-loop to loop over arrays, array methods like map, filter, and reduce enable us to loop over arrays with a certain goal in mind

  • .map() — allows us to transform each element of an array
  • .filter() — allows us to filter out items from arrays that don’t meet a given condition
  • .reduce() — allows us to transform an entire array in whatever way we choose (even into other data types)

These array methods are shorter and more declarative (more clearly express what they do) than a normal for-loop

How are powerful array methods used in React?

Methods like .map(), .filter(), .reduce() can be used wherever we need to transform or shape our array data

Most of the time, you’ll be using these methods to dynamically display components or elements using JSX

  • These methods can be chained together to perform one transformation after another

Why use destructuring in JavaScript?

Destructuring enables us to turn object key-value pairs into variables.

  • Destructuring is a great convenience because we often don’t need to reference an entire object whenever we want to use it.
  • With destructuring, we can just create what looks to some like a reversed version of the object and pluck off what ever values we need, making them independent variables
  • Allows us to reduce repetition by not referencing a single object every time we need a value from it.

Note that destructuring can be also done with arrays as well as normal objects

How is destructuring used in React?

Destructuring is used most often for getting individual values from the props object

  • Most often, we don’t need the entire props object, especially if we pass down only one prop to a given component. Instead of referencing ‘props’, we can just destructure it to get the props data as individual variables in our component.

Default parameters

Why use default parameters in JavaScript?

To handle the event that a function that doesn’t have values passed to it that it needs as arguments

Default parameters helps us prevent errors and have more predictable code by giving arguments default values (with the equals sign) if none are provided

How are default parameters used in React?

Default parameters are often used in the case of props

In this example, we are using object destructuring to grab a prop called ‘username’ from the props object. But no prop value has been passed, so we set a default parameter value of ‘guest’ and our component can still works.

Spread Operator

Why use the spread operator in JavaScript?

The spread operator allows us to “spread” objects (their key-value pairs) into new ones.

  • Spread operator only works when creating a new object or array.

Spread operator is great for creating new objects by merging their properties together.

  • Whenever an object or array is spread into a new object or array, a shallow copy of it is made, which helps prevent errors.

The spread operator can be used with both objects and arrays.

How is the spread operator used in React?

The spread operator is used a great deal for dynamically creating new objects and arrays in an immutable fashion.

  • Often used in common React libraries like Redux to make sure data is changed in a predictable manner.

Specific to React, however, the spread operator is used to easily pass down all of an object’s data as individual props (without having to pass down each prop one-by-one).

  • How does this work? We can spread an object into a component because the props object is what we’re spreading into.

Short Conditionals

Why use short conditionals in JavaScript?

There is a shorter ways of writing an if-else conditional in JavaScript called the ternary.

As compared to an if-else statement, ternaries are expressions. This enables us a lot more flexibility and allows us to use ternaries wherever an expression can be evaluated (such as in the ${} of a template literal).

Ternaries shouldn’t always be preferred over if-else statements, especially if there is more than one condition to evaluated. In that case, ternaries are hard to read.

How are short conditionals used in React?

The benefit of ternaries is that they allow us to more succinct write if-else conditionals in JSX, where if a condition is true, we show one thing, if false, a different thing.

An alternative to the ternary, where if we just want to show one thing if a condition is true, otherwise nothing is the && operator. If the condition is true, return that thing, otherwise, nothing will be shown.

ES Modules

Why use ES Modules in JavaScript?

ES Modules allow us to conveniently share code across multiple files in our application

We export things that we want to pass to other files in our app, primarily variables and functions and import whatever things (that have been exported) within files that need these things

We can export / import multiple things within curly braces (and the keywords export / import) or just one thing with no curly braces (with keywords export default and import)

We usually use modules to make our code more modular, to only write code where we need it, not to put everything in a single file. See below how we have a getLocalTime function that lives in its own file (of the same name), but we bring into app.js to use it there.

How are ES Modules used in React?

ES Modules are used extensively in React to build our applications effectively.

ES Modules are used to import both relative (local files) and absolute imports (packages like React)

  • Local files that have components in them are capitalized (like the component name itself)

We can export and import virtually anything, not just JavaScript (variables and functions), but also CSS and image files, etc

Additionally, in React we often don’t have to add the extension at the end whenever we are importing JavaScript. We only have to add the extension when importing other types of files into our JavaScript, for example:

Promises + Async / Await

Why use promises + async / await in JavaScript?

Certain things in JavaScript don’t happen right away, they take an unknown amount of time (for example, a setTimeout(), an event listener or a network request with the fetch API)

Promises are a means of making asynchronous code in JavaScript predictable. They help us resolve our async code and give us a means of handling the case that it was successful with a .then() callback and a .catch() callback if there was an error in performing that async operation

Async / await is an improved syntax for working with promises that makes our async code looks synchronous and is the most readable way of working with async code

How are promises + async / await used in React?

Promises + async / await are used by far the most for making network requests, such as a request to a REST API or a GraphQL API

Many libraries such as the fetch API or axios use promises to resolve these requests that take an unknown period of time to complete, and promises and async / await are used extensively with these libraries that are used to make network requests

  • See the app in the cheatsheet for a practical example of how data is fetched from an API and resolved with async / await.

What’s Next

There are many other JavaScript features that are used in building great React projects, but these are the ones I believe you must know before any others.

If you would like a quick reference for all of these concepts, plus a real-world React app that shows all of these concepts in action, you can download a free PDF cheatsheet of all this info right here.

Keep coding and I’ll catch you in the next article!


Say hi! 👋 Twittercodeartistry.ioBlog

Reed Barger

Written by

JavaScript developer who loves to write. Delivering the content you need at codeartistry.io 🎨

Code Artistry

Artful coding tips to help you create the life you want.

Welcome to a place where words matter. On Medium, smart voices and original ideas take center stage - with no ads in sight. Watch
Follow all the topics you care about, and we’ll deliver the best stories for you to your homepage and inbox. Explore
Get unlimited access to the best stories on Medium — and support writers while you’re at it. Just $5/month. Upgrade