redux
流程
- 通过store调用dispatch派发action
- store调用相应reducer函数,计算得到新的state并返回
- store将新的state保存下来,触发绑定的订阅函数进行后续操作(如生成新的视图,这一步可以借助React Redux来简化)
特点
- 状态数据只读,保存在store单例,所有的修改来自action
- 不可变数据(immutable.js),使用纯函数reducer修改状态,返回一个新的状态
- store.subsribe订阅变动(react-redux通过mapStateToProps自动完成该订阅)
vuex
流程
- 触发action,执行同步或异步操作
- 在 action 中提交所需的 mutation,在 mutation 函数中改变 state。
- 通过 getter/setter 实现的双向绑定自动更新对应的视图
特点
- 改进了Redux中的Action和Reducer函数,以mutations变化函数取代Reducer, 只需在对应的mutation函数里改变state值即可(直接改动原数据而不是产生新的数据)
- mutations是唯一可以改变state的方式,且每次改变会被vuex记录,实现时间回溯等
- 由于Vue自动重新渲染的特性,无需订阅store,只要改变state即可
mobx
流程
- 在state中定义可观察对象
- 触发action修改state
- state的变更自动触发计算属性的更新及Reactions的响应(如更新视图、打印log等副作用)
特点
- 状态数据可以任意修改,严格模式需要定义action
- 可变数据,即存在副作用
- 可将数据定义为可观察数据,则其变动会触发依赖部分的更新(autorun, reation)
- 原理与vue类似,也是通过defineProperty实现响应式
- mobx会自动收集运行时依赖(即代码里真正用到的依赖)
mobx的哲学:
任何源自应用状态的东西都应该自动地获得。
不应该通过手动订阅来同步状态。这将不可避免地导致超额订阅和遗漏订阅。
只有运行时确定下来的订阅,才是最小的订阅集合。
vue.js官方说法:
在有限程度上,React + Mobx 也可以被认为是更繁琐的 Vue