nanostores is a minimalistic state management library for React applications. It provides a simple and efficient way to manage state in your components without the need for complex setup or boilerplate code. While nanostores offers a lightweight state management solution, there are other libraries in the React ecosystem that provide similar functionality. Here are a few alternatives:
Check out this comparison: Comparing effector vs mobx vs nanostores vs recoil vs zustand.
A tiny state manager for React, React Native, Preact, Vue, Svelte, Solid, Lit, Angular, and vanilla JS. It uses many atomic stores and direct manipulation.
// store/users.ts
import { atom } from 'nanostores'
export const $users = atom<User[]>([])
export function addUser(user: User) {
$users.set([...$users.get(), user]);
}
// store/admins.ts
import { computed } from 'nanostores'
import { $users } from './users.js'
export const $admins = computed($users, users => users.filter(i => i.isAdmin))
// components/admins.tsx
import { useStore } from '@nanostores/react'
import { $admins } from '../stores/admins.js'
export const Admins = () => {
const admins = useStore($admins)
return (
<ul>
{admins.map(user => <UserItem user={user} />)}
</ul>
)
}
Made in Evil Martians, product consulting for developer tools.
Read full docs here.