A glossary of React and related Web terms
JavaScript's real name is ECMAScript — ECMA-TC39 is the standards body that controls it. So the version numbers of "JavaScript" are ES1, ES2 … ES6 etc which stands for ECMAScript Version 6 etc. Version 6 came out in 2015, and they decided to not have the same numbering version anymore. They decided to call ES6 "ES2015" instead. Since then the version numbers have been based on year. But lots of people still refer to them as ES7, ES8 etc.
Stands for "Document Object Model". It's an API which allows JavaScript to manipulate the items on a website. Whereas HTML is a language for describing the content on a website, when the browser interprets HTML they create the DOM from it and when we look at a website we're really looking at the instructions that the DOM is telling the browser to make. So, when something is changing on the website, it's actually the DOM that changed and JavaScript is the thing that tells the DOM to change (sometimes called DOM manipulation). In browsers, JavaScript is the only programming language that can manipulate the DOM. So, if you want a complex web application with dynamic moving parts and user interactions, you're going to need JavaScript (or a JavaScript library/framework) that can manipulate the DOM.
Node is not so much a programming language, but a run-time for JavaScript to run on the server. As such, the JS code you write for node has different globals. In the browser, JS has things like window
and document
. These are missing in Node. Node has things that browser JS doesn't have like process
and access to the filesystem and the ability to make a server.
Stands for "Node Package Manager" and is the de-facto standard JavaScript and Node dependency manager front back-end and front-end third-party dependencies. When you install Node, you get NPM with it.
Any third-party code that your application depends on. If you have a React application, you're going to install React (which is a dependency of your App) with NPM
Modules are just JavaScript files. In Node, a .js
file (module) can be imported into another file with require()
or import
. A module goes a beyond what has been traditional .js
files in the past though because modules encapsulate their contents. Only the things that are exported can be imported into other files. For client-side code, your .js
files can also be modules if you're using a bundler that bundles your code and re-writes it in ways that make each file's contents encapsulated just like they would have been in Node. Webpack and Rollup are examples of client-side bundlers.
Reactive Programming is a paradigm for building applications. Its premise is that as one thing changes, other things will "react" to those changes. The library React is created with this paradigm which is why the library's name is React. Reactive programming can be seen as an alternative to older paradigms like MVC.
A monolithic framework is one that tries to give the developer all the tools they'll need as one big unit. The tradeoff to that vs giving them a more à la carte approach is that there's a cohesiveness to monolithic approaches but less wiggle room to customize things, where as the more à la carte approach requires the developer to use lots of third-party libraries together but this is highly customizable.
Generally speaking, we all know what a website is. It's a collection of pages organized into URLs that we can go to and read content. Technically, a Web Application is no different. You could say that a Web App is a type of Website. But we needed a way to differentiate the types of sites that were starting to be built around 2008 which were much much lager and more sophisticated than that of a normal "website". Things like Twitter, Facebook, LinkedIn, Google Docs, Dropbox, Linked and many more were starting to feel less website-like and more application-like. Not only were they big, they were actually doing technical things to make their sites feel more like an application, including doing this idea called a Single Page Application. Thus, we started calling these types of sites "Web Applications". They're not "Native Apps" like the ones you install from the App Store on your phone, they're still visited in the browser, but they feel like applications.
A technique for building Web Applications so that the browser doesn't do page refreshes in-between page visits but rather uses JavaScript to swap parts of the DOM into and out of the page to give the user a feeling like a page changed. However, since the page didn't actually change, it's one single page that they're viewing the entire time they're on the Web App.
A JavaScript, DOM manipulation framework which uses a monolithic approach and is written in TypeScript (A superset of JavaScript). Angular is made by Google and it would be considered an alternative to React.
A JavaScript, DOM manipulation framework which uses a monolithic approach. Made to resemble "Ruby on Rails" - a server side language and framework. It would be considered an alternative to React.
A JavaScript, DOM manipulation library that uses a component oriented architecture with state management tools built in. It's also made with the "reactive" paradigm. Made by Facebook.
A JavaScript, DOM manipulation library made with the "reactive" paradigm. It would be considered an alternative to React.
A JavaScript, DOM manipulation library made with the "reactive" paradigm. It would be considered an alternative to React.
Any tool(s) or processes that are used (usually third-party) to help the developers while they're developing code and are a part of the build-process — the process of taking the code we write as developers and preparing it for production servers. Webpack and Babel are examples of build-tools.
A "build-tool" that takes JavaScript modules (files) and turns them into one "build-file" aka a "bundle". The end-result build-file is what gets sent to the production servers.
Instead of having a building tool like Webpack generate one giant build file, code-splitting is the idea to configure the app so that Webpack creates separate smaller build files based on some logic.
A JavaScript compiler that can turn alternative types of JavaScript into normal JavaScript. Or it can turn JavaScript that is too modern for most browsers into an older version of JavaScript. Babel can be a plugin to Webpack and can be used to turn React's special JSX syntax into normal JavaScript. Babel is also used to turn TypeScript into JavaScript.
Stands for "Content Delivery Network" which is just a way of saying you're importing third-party code into your site via <script>
or <link>
includes. This is an alternative to using a builder like Webpack where the third-party code would be installed with NPM and then "bundled-into" the project.
A superset of JavaScript that brings "types" to JavaScript. What this translates to is, JavaScript is not a "typed" language. Some developers who like typed languages (like Java and C#) might not like JavaScript because it's not "typed". TypeScript is the exact same thing as JavaScript but with types. Made by Microsoft.
Ordinarily, React is only rendered in the client (the browser). But React can also be rendered on the Server with Node. In this case we call that Server Side Rendering
A framework or tool that allows you to build a website in a way that feels dynamic but through a build-process generates a static website.
A code generator that gives developers a head-start for their Webpack and Babel setups for React. It does not give the developer a way to organize React or any SSR tools.
A React Framework which creates a hybrid of an SPA and SSR. The SSR is by virtue of dynamic pages. It has a prescribed way to organize code which has some limitations regarding layouts
A React Framework which creates a hybrid of an SPA and SSR. The SSR is by virtue of its Static Site Generator. It has a prescribed way to organize code which has some limitations regarding layouts
A React Framework which creates a hybrid of an SPA and SSR. The SSR is by virtue of dynamic pages. It has a prescribed way to organize code which rely's on React Router which doesn't have the same limitations as NextJS and Gatsby. It also does code-splitting out-of-the-box
A third-part module for React that helps React become a Single Page Application.
Originally, the term component meant a re-usable piece of UI such as a Calendar Component or a Button Component. When web developers look at a website, we tend to see it in terms of a big collection of components all being used together. React is a JavaScript library to manipulate the DOM, but it does so by creating a system where you defined your code into these logical groups that they call "components". In React, components are the fundamental building blocks for everything — kind of like small lego bricks that can be used to make anything. Sometimes you might have a React component that perfectly aligns with the traditional idea of what it meant to be a component, like a React Button or Calendar. But since components are the fundamental building blocks for all things in React, we actually use them to build lots of other stuff that someone like a graphic designer would never consider to be a "component" in their line of work. In React, a component is a piece of re-usable code.
A component made from a JavaScript function. Before "Hooks", Function Components were inferior to Class ones because they couldn't have state
A component made from a JavaScript class. Before "Hooks", Class Components were the only way to have state and lifecycle methods for components.
Methods of Class Components which help the component do things at certain intervals of time, like when the component first mounts, updates, or unmounts.
This is not a third type of React Component, but rather a design pattern for creating re-usable code abstractions with Class Components. This pattern was mostly popular in the 2015-2017 era in React. Redux largely helped to popularize this pattern.
This is a pattern for creating re-usable code abstractions. It's an alternative to HoC's and starting around 2017 started to be considered a better alternative by many because it solved several shortcomings that HoC's had. However, Render Props have some shortcomings of their own that HoC's didn't have to begin with.
In October of 2018, the React team revealed a new way to write React components. A "hook" is a feature for the Function Components to have access to the full API of React just like how Class Components have always had. This means that Function Components are no longer inferior to Class ones. Hooks solve a number of problems that Class components had to begin with and they give us a new primitive way to do code sharing abstractions so we don't have to rely on the HoC and "Render Props" patterns which had shortcomings. Generally speaking, when a project is using Function Components with Hooks instead of Class Components, the code in each component will be smaller, more bug free (solving some common bugs found in classes) and the abstractions are much cleaner than HoC and Render Props.
It's also worth mentioning that Class-based Components are not deprecated and a project with Class-based ones can slowly migrate one component at a time to Function Components with Hooks since they can co-exist.
These are not other "types" of components. A "Pure" component is a Class Component that has some performance optimizations turned on. A "memoized" component is a Function Component with similar optimizations turned on. The reason why components don't have these "optimizations" on by default is because they do come with some overhead costs that you would have to incur for all components even though only some components might benefit from these optimizations. So they're opt-in only.
In React, Components are organized into a hierarchy of parent and child components which ends up creating somewhat of a "tree-structure" similar to a family tree diagram. Components can pass each other information via "props" or "context"
In React, a "prop" (short for property) is a basic way to pass information from parent to child components. When props are sent down through many levels of components, this can sometimes be referred to as "prop-drilling". Prop-drilling isn't supposed to be a good thing or a bad thing, but just a term that describes what's happening. Sometimes developers think prop drilling might be getting excessive and they might prefer to change to "context" for the particular situation.
In React, props are probably the easiest way to pass information around. But in a large application with many components, it can be a little cumbersome with lots of "prop-drilling". So "context" is an alternative way to pass information around where you can pass information from one component to another all while skipping all the components in-between. Technically, components can't pass data directly between each other except for parents passing props to children, so context works by creating a PubSub pattern (publish-subscribe patter) whereby the publishers are called "providers" and the subscribers are called "consumers"
- A Context Provider is a component sending data out.
- A Context Consumer is a component that is "subscribed" to that provider and receiving the data.
In React, state means information that can possibly change. If a component loads some user information, we would store that in "state". If we have some piece of UI that toggles on and off or has multiple "UI states" like a dropdown menu being open or closed, then we store that data about the toggle or menu in React's "state". For the most part, React's State is similar to what a "variable" is in programming but it also has some nuanced details that are React-specific.
When a component has state which originates inside of it, we call that "local state" — as in, local to that component.
When Component A has local state and needs to share that information with Component B, Component A could pass that information via Props or Context to component B.
When your application needs data to be shared among all components, we might call that application state. Redux is a third-party tool which in the past has been used as a way to do Application State in React. More recently, React has built-in features that help us create application state which we call Context.
Redux and MobX are third-party tools for doing application state. They are framework agnostic so they're not meant just for React. They're general purpose tools to share state across an entire application. In previous years, React didn't have a really good way to share state across the entire component hierarchy, so Redux was really popular as a third-party tool in React applications. These days, Redux is still fairly popular but React now has internal features that developers can use to achieve the same goal of application-wide state sharing. The tool in React is called "Context".
Stands for "JavaScript and XML". It's a syntax that React created in order to help developers author DOM manipulation instructions. JSX looks very similar to HTML which developers are already familiar with. Since browsers don't understand JSX though, developers use a build-process with Babel to compile the JSX code into ordinary JavaScript. So the files we write as developers have JSX in them, but the code that gets sent to production does not. JSX is largely credited as being the number one aspect of React that has made it so successful.
In React, we say that a component is "mounted" if the component is actively being used to create the DOM. In fact, we would say the component is "mounted to the DOM". In order to mount, the component has to be "rendered" for the first time. After this first "render and mount" a component can experience a number of "re-renders" which is just a way to get updated instructions from the component do to some sort of change that occurred in the code.
When a React component renders (or re-renders), it's instructions for creating or updating DOM are examined by React so that React can optimize the actual DOM changes for performance.
React keeps track in memory of what it thinks the real DOM should look like, this "copy" of the DOM that React keeps is called the Virtual DOM (virtual because it's not the real one). When React is doing reconciliation, it uses its Virtual DOM and compares it to the changes being sent over from the components optimize what needs to be changed in the real DOM - this is reconciliation.
As a general programming term, "side effects" is when a function reaches outside of itself to accomplish its task. In React, we say a component has "side effects" if the component reaches outside of itself (usually outside of JavaScript) to accomplish a task. Some examples would be: Doing Network API requests to communicate with the server, working with Cookies or Local Storage, etc.
This is a technique for writing code such that a long-running task can be happening outside of JavaScript and allowing JavaScript to continue to run and not put everything on hold while it waits for the task to finish.
A "promise" is a JavaScript pattern that helps to do asynchronous code. "Async/Await" is a more modern syntax for doing promises.
JavaScript does not have threads. I just put this in here so that we're clear about this. Instead, JavaScript solves need to "doing many things at once" with asynchronous code.
AJAX is really just unofficial "slang" for what is really an XHR Request. XHR is the tool in browsers that's existed since the early 2000's that allows JavaScript and browsers to communicate over the network with servers to get responses without doing full-page refreshes. XHR is asynchronous and was created before promises. Because of the XHR API being so old, spec creators wanted to make a more modern alternative to XHR based on promises called Fetch. Today, developers still use XHR and/or Fetch to build complex "application-like" websites that don't have to do refreshes — like Single Page Applications. There's also a bunch of third-party libraries that wrap around these technologies. One that is popular is Axios which is a promise-based abstraction for XHR with other value-added concepts.