从第一个Redux Commit到如今,已快四年了。期间,陆陆续续有各类对于Redux进行再设计与封装的探索,其中以OOP设计尤其突出,而usm-redux
即是一个完全改变Redux固有使用方式的库。react
从根本上说,usm-redux
是一个彻底为OOP而生的Redux再封装库,它让Redux的使用变得无比简洁。git
接下来咱们先看一个redux官方文档中的经典Todo例子:github
import { createStore, combineReducers } from 'redux'
// action
let nextTodoId = 0
const addTodo = text => {
return {
type: 'ADD_TODO',
id: nextTodoId++,
text
}
}
const setVisibilityFilter = filter => {
return {
type: 'SET_VISIBILITY_FILTER',
filter
}
}
const toggleTodo = id => {
return {
type: 'TOGGLE_TODO',
id
}
}
// reducers
const todos = (state = [], action) => {
switch (action.type) {
case 'ADD_TODO':
return [
...state,
{
id: action.id,
text: action.text,
completed: false
}
]
case 'TOGGLE_TODO':
return state.map(todo =>
(todo.id === action.id)
? {...todo, completed: !todo.completed}
: todo
)
default:
return state
}
}
const visibilityFilter = (state = 'SHOW_ALL', action) => {
switch (action.type) {
case 'SET_VISIBILITY_FILTER':
return action.filter
default:
return state
}
}
const todoApp = combineReducers({
todos,
visibilityFilter
})
复制代码
这里只是为了写一个简单的todo,但Redux的boilerplate显然就是如此。redux
下面是一个usm-redux
的todo例子(和上面彻底同样的逻辑实现):缓存
import Module, { state, action } from 'usm-redux'
class TodoList extends Module {
@state todos = []
@state visibilityFilter = 'SHOW_ALL'
nextTodoId = 0
@action
add(text, state) {
this.nextTodoId++
state.todos.push({
text,
id: this.nextTodoId,
completed: false,
})
}
@action
toggle(id, state) {
const todo = state.todos.find(todo => todo.id === id)
todo.completed = !todo.completed
}
@action
setVisibility(filter, state) {
state.visibilityFilter = filter
}
}
复制代码
usm-redux
只有@state
和 @action
的定义,除此之外,与你常用的类的OOP彻底一致。 一个彻底等价的TODO之间的比较,咱们能够发现,usm-redux
逻辑靠近与更贴近OOP的方式,让想使用OOP的人驾轻就熟。 同时usm-redux
还提供了@computed
来进行衍生计算的缓存。它能极大的优化react衍生数据的重复计算。模块化
class Shop extends Module {
@state goods = [];
@state status = 'close';
@action
operate(item, status, state) {
state.goods.push(item);
state.status = status;
}
// call -> this.operate({ name: 'fruits', amount: 10 }, 'open');
@computed
shortages = [
() => this.goods,
(goods) => goods.filter(item => item.amount < 5)
];
}
复制代码
模块化地使用usm-redux
将让你的项目也商业逻辑变得更加内聚。同时配合React的Hooks, 让React+Redux轻松实如今高内聚和低耦合。学习
随便提一下,usm-redux
是一个基于通用化状态模块的概念而设计usm
。简单说,usm
就是能够让你轻松使用Redux/Vuex/MobX等主流状态库而不用费心去分别学习和使用它们。优化
更多关于usm-redux
的features以及usm
,能够访问Repo: github.com/unadlib/usm。ui