一個完全改變Redux的簡潔設計

從第一個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/usmui

相關文章
相關標籤/搜索