Skip to content

quguoliang/rematch

 
 

Repository files navigation

Rematch

Chat on slack Build Status Coverage Status Npm version Bundle size File size lerna

Rematch is Redux best practices without the boilerplate. No more action types, action creators, switch statements or thunks.

Check out the website for the full documentation: https://rematch.github.io/rematch

Features

Redux is an amazing state management tool, supported by a healthy middleware ecosystem and excellent devtools. Rematch builds upon Redux by reducing boilerplate and enforcing best practices. It provides the following features:

  • No configuration needed
  • Reduces Redux boilerplate
  • Built-in side-effects support
  • React Devtools support
  • TypeScript support
  • Supports dynamically adding reducers
  • Supports hot-reloading
  • Allows to create multiple stores
  • Supports React Native
  • Extendable with plugins
  • Many plugins available out of the box:

Redux vs Rematch

Redux Rematch
simple setup ‎ ‎✔
less boilerplate ‎✔
readability ‎✔
configurable ‎ ✔ ‎✔
redux devtools ‎✔ ‎✔
generated action creators ‎✔
async thunks ‎async/await

Migrate From Redux

Migrating from Redux to Rematch may only involve minor changes to your state management, and no necessary changes to your view logic. See the migration reference for the details.

Composable Plugins

Rematch and its internals are all built upon a plugin pipeline. As a result, developers can make complex custom plugins that modify the setup or add data models, often without requiring any changes to Rematch itself. See the plugins developed by the Rematch team or the API for creating plugins.

Contact & Support

License

This project is licensed under the MIT license.

<script async defer src="https://buttons.github.io/buttons.js"></script>

Packages

No packages published

Languages

  • JavaScript 75.3%
  • TypeScript 23.4%
  • Other 1.3%