NPM Star
Collections
  1. Home
  2. Compare
  3. jotai vs recoil
NPM Compare

Compare NPM packages statistics, trends, and features

CollectionsVS Code extensionChrome extensionTermsPrivacyLinkTreeIndiehackersBig Frontendqiuyumi

Jotai vs Recoil: Modern Atomic State Management for React

Both Jotai and Recoil are state management libraries for React that use an atomic approach, meaning they break down state into small, independent pieces. They help developers manage complex application state without the boilerplate of Redux. These libraries are especially good for when you need to share data between different components without prop drilling.

State ManagementReactState ManagementAtomicPerformance

Detailed Comparison

Technical Analysis

featureComparison

Both jotai and recoil are state management libraries for React. They provide a way to manage global state by creating atoms (in jotai) or recoil state (in recoil). jotai is more lightweight and flexible, while recoil is more feature-rich and opinionated.

typescriptSupport

Both jotai and recoil have excellent TypeScript support, with jotai having a slight edge in terms of type inference.

browserCompatibility

Both libraries are compatible with modern browsers, including Chrome, Firefox, and Edge.

dependencies

jotai has no dependencies, while recoil depends on react.

performance

jotai is generally faster and more lightweight than recoil due to its smaller bundle size and more efficient update mechanism.

Ecosystem Analysis

frameworkCompatibility

Both jotai and recoil are compatible with React, but recoil is more tightly integrated with the React ecosystem.

communityActivity

recoil has a more active community and more contributors, but jotai is gaining popularity rapidly.

documentationQuality

Both libraries have excellent documentation, but recoil's documentation is more comprehensive and better organized.

maintenanceStatus

Both libraries are actively maintained, with recoil having a more frequent release cycle.

Performance Comparison

bundleSizeAnalysis

jotai's bundle size is significantly smaller than recoil's, making it a better choice for smaller applications.

runtimePerformance

jotai is generally faster than recoil due to its more efficient update mechanism.

loadingTime

jotai loads faster than recoil due to its smaller bundle size.

memoryUsage

jotai uses less memory than recoil due to its more efficient state management mechanism.

Code Examples

Basic jotai example

1import { atom, useAtom } from 'jotai';
2const countAtom = atom(0);
3function Counter() {
4  const [count, setCount] = useAtom(countAtom);
5  return (
6    <div>
7      <p>Count: {count}</p>
8      <button onClick={() => setCount(count + 1)}>Increment</button>
9    </div>
10  );
11}

This example creates a simple counter using jotai's atom and useAtom hooks.

Basic recoil example

1import { atom, selector, useRecoilState } from 'recoil';
2const countState = atom({
3  key: 'count',
4  default: 0,
5});
6function Counter() {
7  const [count, setCount] = useRecoilState(countState);
8  return (
9    <div>
10      <p>Count: {count}</p>
11      <button onClick={() => setCount(count + 1)}>Increment</button>
12    </div>
13  );
14}

This example creates a simple counter using recoil's atom and useRecoilState hooks.

Recommendation

Summary

Both jotai and recoil are excellent state management libraries for React. jotai is a better choice for smaller applications or those requiring more flexibility, while recoil is a better choice for larger applications or those requiring more features.

Details

  • jotai is more lightweight and flexible
  • recoil is more feature-rich and opinionated

Similar Packages

zustand

90%

A small, fast state management solution that uses hooks. It's super simple to learn and doesn't require much setup code like other state managers.

Like Jotai and Recoil, it's modern and hook-based. It's becoming very popular because it's easier to learn than Redux and has a tiny bundle size. Perfect for small to medium React apps.

State Management

valtio

85%

A proxy-based state management tool that makes your React state work like regular JavaScript objects. You can update state directly without special actions or reducers.

It's made by the same team as Jotai and shares similar principles of simplicity. Great for developers who want their state management to feel more natural and less framework-specific.

State Management

nanostores

70%

A tiny state manager that works with any framework, not just React. It's super lightweight and focuses on simplicity and speed.

While not as React-specific as Jotai or Recoil, it offers atomic state management in a similar way. It's perfect for those who want something extremely lightweight or might work with multiple frameworks.

State Management

mobx

60%

A battle-tested state management library that makes state management as simple as working with plain JavaScript objects. It uses a reactive programming approach.

While it's older than Jotai and Recoil, it offers similar benefits of simple state management with less boilerplate than Redux. Good for larger applications that need more features.

State Management
<br>

Jotai (light mode)

<br>

visit jotai.org or npm i jotai

Build Status Build Size Version Downloads Discord Shield Open Collective

Jotai scales from a simple useState replacement to an enterprise TypeScript application.

  • Minimal core API (2kb)
  • Many utilities and extensions
  • No string keys (compared to Recoil)

Examples: Demo 1 | Demo 2

First, create a primitive atom

An atom represents a piece of state. All you need is to specify an initial value, which can be primitive values like strings and numbers, objects, and arrays. You can create as many primitive atoms as you want.

import { atom } from 'jotai' const countAtom = atom(0) const countryAtom = atom('Japan') const citiesAtom = atom(['Tokyo', 'Kyoto', 'Osaka']) const mangaAtom = atom({ 'Dragon Ball': 1984, 'One Piece': 1997, Naruto: 1999 })

Use the atom in your components

It can be used like React.useState:

import { useAtom } from 'jotai' function Counter() { const [count, setCount] = useAtom(countAtom) return ( <h1> {count} <button onClick={() => setCount((c) => c + 1)}>one up</button> ...

Create derived atoms with computed values

A new read-only atom can be created from existing atoms by passing a read function as the first argument. get allows you to fetch the contextual value of any atom.

const doubledCountAtom = atom((get) => get(countAtom) * 2) function DoubleCounter() { const [doubledCount] = useAtom(doubledCountAtom) return <h2>{doubledCount}</h2> }

Creating an atom from multiple atoms

You can combine multiple atoms to create a derived atom.

const count1 = atom(1) const count2 = atom(2) const count3 = atom(3) const sum = atom((get) => get(count1) + get(count2) + get(count3))

Or if you like fp patterns ...

const atoms = [count1, count2, count3, ...otherAtoms] const sum = atom((get) => atoms.map(get).reduce((acc, count) => acc + count))

Derived async atoms <img src="https://img.shields.io/badge/-needs_suspense-black" alt="needs suspense" />

You can make the read function an async function too.

const urlAtom = atom('https://json.host.com') const fetchUrlAtom = atom(async (get) => { const response = await fetch(get(urlAtom)) return await response.json() }) function Status() { // Re-renders the component after urlAtom is changed and the async function above concludes const [json] = useAtom(fetchUrlAtom) ...

You can create a writable derived atom

Specify a write function at the second argument. get will return the current value of an atom. set will update the value of an atom.

const decrementCountAtom = atom( (get) => get(countAtom), (get, set, _arg) => set(countAtom, get(countAtom) - 1) ) function Counter() { const [count, decrement] = useAtom(decrementCountAtom) return ( <h1> {count} <button onClick={decrement}>Decrease</button> ...

Write only derived atoms

Just do not define a read function.

const multiplyCountAtom = atom(null, (get, set, by) => set(countAtom, get(countAtom) * by), ) function Controls() { const [, multiply] = useAtom(multiplyCountAtom) return <button onClick={() => multiply(3)}>triple</button> }

Async actions

Just make the write function an async function and call set when you're ready.

const fetchCountAtom = atom( (get) => get(countAtom), async (_get, set, url) => { const response = await fetch(url) set(countAtom, (await response.json()).count) } ) function Controls() { const [count, compute] = useAtom(fetchCountAtom) return ( <button onClick={() => compute('http://count.host.com')}>compute</button> ...

Note about functional programming

Jotai's fluid interface is no accident — atoms are monads, just like promises! Monads are an established pattern for modular, pure, robust and understandable code which is optimized for change. Read more about Jotai and monads.

Links

  • website
  • documentation
  • course

Recoil · NPM Version Node.js CI GitHub license Follow on Twitter

Recoil is an experimental state management framework for React.

Website: https://recoiljs.org

Documentation

Documentation: https://recoiljs.org/docs/introduction/core-concepts

API Reference: https://recoiljs.org/docs/api-reference/core/RecoilRoot

Tutorials: https://recoiljs.org/resources

Installation

The Recoil package lives in npm. Please see the installation guide

To install the latest stable version, run the following command:

npm install recoil

Or if you're using yarn:

yarn add recoil

Or if you're using bower:

bower install --save recoil

Contributing

Development of Recoil happens in the open on GitHub, and we are grateful to the community for contributing bugfixes and improvements. Read below to learn how you can take part in improving Recoil.

  • Code of Conduct
  • Contributing Guide

License

Recoil is MIT licensed.

Dependencies Comparison

jotai

Dependencies

Dev Dependencies

Peer Dependencies

@types/react>=17.0.0
react>=17.0.0

recoil

Dependencies

hamt_plus1.0.2

Dev Dependencies

Peer Dependencies

react>=16.13.1
StarsIssuesVersionUpdatedⓘLast publish dateCreatedⓘPackage creation dateSizeⓘMinified + Gzipped size
J
jotai
20,11242.12.5a month ago5 years agoinstall size 4.0 KB
R
recoil
19,6073230.7.716 months ago5 years agoinstall size 23.5 KB