Project Awesome project awesome

State Management > effector

Fast and powerful reactive state manager. Effector lets you write simple, fast and type safe code and manage reactive state with ease.

Package 4.8k stars GitHub

Effector Comet Logo


join gitter build status discord chat become a patron Ask DeepWiki

☄️ effector

Business logic with ease

Visit effector.dev for docs, guides and examples

Table of Contents

Introduction

Effector implements business logic with ease for Javascript apps (React/React Native/Vue/Svelte/Node.js/Vanilla), allows you to manage data flow in complex applications. Effector provides best TypeScript support out of the box.

Effector follows five basic principles:

  • Application stores should be as light as possible - the idea of adding a store for specific needs should not be frightening or damaging to the developer.
  • Application stores should be freely combined - data that the application needs can be statically distributed, showing how it will be converted in runtime.
  • Autonomy from controversial concepts - no decorators, no need to use classes or proxies - this is not required to control the state of the application and therefore the api library uses only functions and plain js objects
  • Predictability and clarity of API - a small number of basic principles are reused in different cases, reducing the user's workload and increasing recognition. For example, if you know how .watch works for events, you already know how .watch works for stores.
  • The application is built from simple elements - space and way to take any required business logic out of the view, maximizing the simplicity of the components.

Installation

You can use any package manager

npm install effector

React

To getting started read our article how to write React and Typescript application.

npm install effector effector-react

SolidJS

npm install effector effector-solid

Vue

npm install effector effector-vue

Svelte

Svelte works with effector out of the box, no additional packages needed. See word chain game application written with svelte and effector.

CDN

Documentation

For additional information, guides and api reference visit our documentation site

Packages

Articles

Community

Online playground

You can try effector with online playground

Code sharing, Typescript and react supported out of the box. Playground repository

DevTools

Use effector-logger for printing updates to console, displaying current store values with ui or connecting application to familiar redux devtools


More examples in documentation

Learn more

Support us

Your support allows us to improve the developer experience 🧡.

Contributors

Dmitry
Dmitry
andretshurotshka
andretshurotshka
Sova
Sova
Alexander
Alexander Khoroshikh
popuguy
popuguy
Igor
Igor Kamyşev
Nikita
Nikita Kungurcev
pxbuffer
pxbuffer
Valeriy
Valeriy Kobzar
Yan
Yan
Ruslan
Ruslan @doasync
Illia
Illia Osmanov
mg901
mg901
Igor
Igor Ryzhov
Edward
Edward Gigolaev
Viktor
Viktor
Arthur
Arthur Irgashev
Ilya
Ilya
Mikhail
Mikhail Kireev
Ainur
Ainur
Ilya
Ilya Olovyannikov
Arutyunyan
Arutyunyan Artem
Dmitrij
Dmitrij Shuleshov
Nikita
Nikita Nafranets
Ivan
Ivan Savichev
Aleksandr
Aleksandr Osipov
bakugod
bakugod
Зухриддин
Зухриддин Камильжанов
Mikhail
Mikhail Krilov
Victor
Victor Didenko
Viktor
Viktor Pasynok
Kirill
Kirill Mironov
Andrei
Andrei
Denis
Denis
Filipkin
Filipkin Denis
Ivan
Ivan
Ivanov
Ivanov Vadim
sergey20x25
sergey20x25
Rastrapon
Rastrapon
Dan
Dan
Bohdan
Bohdan Petrov
Bartłomiej
Bartłomiej Wendt
Ivan
Ivan
Tauyekel
Tauyekel Kunzhol
Victor
Victor
Vitaly
Vitaly Afonin
Vladimir
Vladimir Ivakin
Aldiyar
Aldiyar Batyrbekov
cqh
cqh
R
R I
☃︎
☃︎
Andrei
Andrei Antropov
Aleksandr
Aleksandr Belov
an.chmelev
an.chmelev
Anton
Anton Kosykh
Anton
Anton Yurovskykh
Arsen-95
Arsen-95
Chshanovskiy
Chshanovskiy Maxim
Denis
Denis Sikuler
Kirill
Kirill
Renat
Renat Sagdeev
Samir
Samir
Matvei
Matvei Tratseuski
Sozonov
Sozonov
Yesset
Yesset Zhussupov
Rasul
Rasul
Will
Will Heslam
Vladislav
Vladislav Botvin
Vladislav
Vladislav Melnikov
Vladislav
Vladislav
Victor
Victor Kolb
Vasili
Vasili Svirydau
Vasili
Vasili Sviridov
Usman
Usman Yunusov
The
The Gitter Badger
Simon
Simon Muravev
Shiyan7
Shiyan7
Sergey
Sergey Belozyorcev
Satya
Satya Rohith
falkomerr
falkomerr
Roman
Roman
Robert
Robert Kuzhin
Gabriel
Gabriel Husek
xxxxue
xxxxue
vladthelittleone
vladthelittleone
Vladimir
Vladimir Skripnik
Vladimir
Vladimir
roman
roman
Eris
Eris
masawik
masawik
lightningmq
lightningmq
Kirill
Kirill Leushkin
kanno
kanno
Ilya
Ilya
ilfey
ilfey
Houston
Houston (Bot)
Grigory
Grigory Zaripov
dmitryplyaskin
dmitryplyaskin
Stanislav
Stanislav
Артём
Артём Жолудь
ansunrisein
ansunrisein
Anatoly
Anatoly Kopyl
Ed
Ed Prince
Dmitry
Dmitry Dudin
Dmitry
Dmitry
Denis
Denis Skiba
Dinislam
Dinislam Maushov
Ayu
Ayu
David
David
Egor
Egor Gorochkin
Amar
Amar Sood
Александр
Александр
Alexander
Alexander
Alex
Alex Anokhin
Alex
Alex Arro
Aleksandr
Aleksandr Grigorii
Abel
Abel Soares Siqueira
7iomka
7iomka
Abdukerim
Abdukerim Radjapov
0xflotus
0xflotus
Raman
Raman Aktsisiuk
Rachael
Rachael Dawn
Philipp
Philipp
bigslycat
bigslycat
Oleh
Oleh
Oleg
Oleg
Mike
Mike Cann
Nikita
Nikita Svoyachenko
Marco
Marco Pasqualetti
Ludovic
Ludovic Dem
Leniorko
Leniorko
Lebedev
Lebedev Konstantin
Joel
Joel Bandi
Jesse
Jesse Jackson
Jan
Jan Keromnes
Ivan
Ivan
Infant
Infant Frontender
Ilya
Ilya Martynov
Gleb
Gleb Kotovsky

Tested with browserstack

Back to Vue.js