ReactStateMuseum VS crank

Compare ReactStateMuseum vs crank and see what are their differences.

Our great sponsors
  • SurveyJS - Open-Source JSON Form Builder to Create Dynamic Forms Right in Your App
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
ReactStateMuseum crank
4 13
1,551 2,670
- 1.3%
0.0 6.5
about 1 year ago 8 days ago
JavaScript TypeScript
MIT License MIT License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

ReactStateMuseum

Posts with mentions or reviews of ReactStateMuseum. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-03-02.
  • Best place to find a whole list of react native libraries?
    2 projects | /r/reactnative | 2 Mar 2022
    Also, there's this for state management: https://github.com/GantMan/ReactStateMuseum
  • React State Museum - Examples to help portray the how, why, which, pros, and cons of various state management systems in the React ecosystem
    1 project | /r/reactjs | 29 Nov 2021
    2 projects | /r/javascript | 29 Nov 2021
  • My current views of state management in React
    1 project | dev.to | 14 Mar 2021
    React development has always had a bit of a choose your own adventure experience. By that I mean there are a LOT of choices to make in any react app. Other frameworks are much more prescriptive in how you build applications. You won't get very far down your adventure before you must make some choices in how you handle data and state within your application. React components can have state using setState in a class component or useState in a function component. That along with context is really all React gives you out of the box. Over the years there have been countless state management solutions that have risen and fallen in popularity. Have a look at React State Museum to see dozens of the most popular approaches over the years. There was a time where it looked like Redux was going to be the clear winner and for maybe a couple of years it did seem like every enterprise react app was built with redux. It's sort of fallen out of favor in recent years although it is still a solid pattern. Over the years my preferences have changed as the options have expanded. Back in the redux hay day I was all in on global state management but these days I do not find myself reaching for a global state management solution. I'll try to break down my preferences for data/state management. So pretty much every app out there talks to some sort of API to query/mutate data on the server. I prefer to synchronize my app with the serve using React Query or Apollo Client. I've been working mostly with GraphQL APIs in recent years so I've typically found myself using Apollo Client. Apollo client has a memory cache that your app can use to synchronize the UI with the server. I only recently learned about React-Query which has a very similar API as Apollo Client with the useQuery hook, but can be used with anything that returns a promise like the Fetch API for example. React Query is useful for synchronizing your app with server data regardless of if it is GraphQL or REST, or something else. I find that once your app data is synchronized with the server using one of these approaches, then there is not really much left that needs to go into global state. It is worth noting that Apollo Client does allow you to add some local state to the cache, but I’ve found it to be a little heavy handed for my tastes. Most apps you will want some state available globally for example you might want to track dark mode settings, or if a particular modal is open and things of this nature. In these cases I find useState or useReducer with React Context is sufficient. I tend to prefer to keep my state closer to where it is relevant. I do have a fascination with Finite State Machines - and XState is awesome for state machines in your app. I do like to use state machines at the component level, for complex operations or to orchestrate some nuanced sequence or application flow.

crank

Posts with mentions or reviews of crank. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-03-08.
  • Coroutines in JavaScript for Web Components
    3 projects | news.ycombinator.com | 8 Mar 2024
    If you enjoy this approach, you might enjoy the Crank JS framework. https://crank.js.org/

    > Crank uses generator functions to define stateful components. You store state in local variables, and `yield` rather than `return` to keep it around.

  • Crank.js, the Just JavaScript Framework
    1 project | news.ycombinator.com | 2 Oct 2023
  • A Proposal for an asynchronous Rust GUI framework
    9 projects | news.ycombinator.com | 3 Sep 2023
    I'm very interested in seeing if using the commonly implemented forms of compiler support for async programming can also be well used for GUI programming. One wishawa[0] is also perusing this approach in Rust but I first came upon this idea from the crank-js[1] authors. It wasn't clear to me why that one never went anywhere. Was it failure with the approach or was React just a good solution in the space? I can say this though, there's something strikingly elegant about those initial samples of using JavaScript generators for components.

    [0]: https://github.com/wishawa/async_ui

    [1]: https://github.com/bikeshaving/crank

    6 projects | /r/rust | 2 Jun 2023
    Take a look at crank.js, a JavaScript framework where components can be written as async functions or as generators. It seems similar to what you're trying to do :)
  • UnsuckJS: Progressively enhance HTML with lightweight JavaScript libraries
    7 projects | news.ycombinator.com | 15 Jun 2023
  • Algebraic Effects – You Can Touch This (2019)
    1 project | news.ycombinator.com | 14 Dec 2022
    Well there's https://crank.js.org that uses native js generators where you would you normally put hooks in. Never used it but looked like a very neat idea.
  • What happens if you mix React, Mobx and generators*? Ok, let's do it!
    1 project | /r/javascript | 25 Jul 2022
    Reminds me of https://github.com/bikeshaving/crank, which was rather fun for a PoC I made a while back.
  • Are my components supposed to render multiple times?
    2 projects | /r/reactjs | 20 Feb 2022
    Strictly speaking, the framework hides this complexity away, but it still exists and it is the framework that's now paying the extra cost. Of course a framework is allowed, and should, when possible, hide away these things. For example Crank.js uses generators to allow for async Components as first class citizens, https://github.com/bikeshaving/crank, but they're still having to deal with the pitfalls of asynchronous work.
  • React State Museum - Examples to help portray the how, why, which, pros, and cons of various state management systems in the React ecosystem
    2 projects | /r/javascript | 29 Nov 2021
    To give the author of https://crank.js.org/ due credit, after reading through the descriptive posts I was impressed by the amount of thought and design that went into it.
  • What's New in React 18?
    3 projects | news.ycombinator.com | 29 Sep 2021
    > What do you propose as an alternative?

    There are lots of alternatives, but perhaps the simplest would have been to use async generators. This is how Crank[0] (mentioned elsewhere in this thread) works, and it allows you to do anything (AFAIK) that's possible with hooks with a much simpler and more testable API.

    > So, sure, there are limitations and rules you have to pay attention to with hooks... but that's just programming.

    No, it's not. The biggest problem with React hooks is that they are not composed of transferable knowledge, meaning memorizing these rules and patterns does not transfer outside of React; likewise, I can't use much of the knowledge I have already built up over many years of my career when using hooks. It's the same argument that's made against Rails, where you have to learn tons of Rails-specific idioms (on top of having to understand general concepts like relational database access patterns) instead of just writing code in a way that's more direct and intuitive for anyone.

    My brain has limited RAM. The more things I have to keep in my head when developing against an API, the more likely I am to make a mistake. With every release of React, I seem to have to keep more and more of these details in my brain as I work. Contrast this with something like Svelte, where you really only need to fully grok about two concepts to use it effectively. I understand that this is the tradeoff the React team made, but I'm not convinced it's worth it.

    [0]: https://crank.js.org/ and https://crank.js.org/blog/introducing-crank

What are some alternatives?

When comparing ReactStateMuseum and crank you can also consider the following projects:

react-singleton-hook - Create singleton hook from regular react hook

js-framework-benchmark - A comparison of the performance of a few popular javascript frameworks

rematch - The Redux Framework

React - The library for web and native user interfaces.

easy-peasy - Vegetarian friendly state for React

async_ui - Lifetime-Friendly, Component-Based, Retained-Mode UI Powered by Async Rust

mozaik - 🔮 State manager for write good code. Best from redux, mobx and mobx-state-tree

ava - Node.js test runner that lets you develop with confidence 🚀

reactant - A framework for building React applications

sucrase - Super-fast alternative to Babel for when you can target modern JS runtimes

react-boilerplate - :fire: A highly scalable, offline-first foundation with the best developer experience and a focus on performance and best practices.

solid - A declarative, efficient, and flexible JavaScript library for building user interfaces.