美文网首页
一个彻底改变Redux的简洁设计

一个彻底改变Redux的简洁设计

作者: unadlib | 来源:发表于2019-03-31 22:49 被阅读0次

从第一个Redux Commit到现在,已快四年了。期间,陆陆续续有各种对于Redux进行再设计与封装的探索,其中以OOP设计尤为突出,而usm-redux便是一个彻底改变Redux固有使用方式的库。

从根本上说,usm-redux是一个完全为OOP而生的Redux再封装库,它让Redux的使用变得无比简洁。

接下来我们先看一个redux官方文档中的经典Todo例子:

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显然就是如此。

下面是一个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: https://github.com/unadlib/usm

相关文章

  • 一个彻底改变Redux的简洁设计

    从第一个Redux Commit到现在,已快四年了。期间,陆陆续续有各种对于Redux进行再设计与封装的探索,其中...

  • 20.redux使用

    react-redux 使用一个react-redux 的库使得redux的使用更简洁,它提供了provider和...

  • 简易Redux库的实现

    基础Redux实现 Redux的强大之处也由于它的简洁,我们甚至可以用几行代码来实现一个简易的Redux生态。 R...

  • Redux从设计到源码

    Redux背后的设计思想 在讲设计思想前,先简单讲下Redux是什么?我们为什么要用Redux? Redux是什么...

  • Redux原理分析

    redux介绍 redux是一个针对JavaScript应用的可预测的状态管理器。 redux中的设计模式 装饰者...

  • react-redux应用

    react-redux是把redux进一步封装,适配react项目,让redux更加简洁 在真实项目中使用reac...

  • redux 总结

    redux redux概念 Redux是JavaScript应用程序的可预测状态容器。 redux 设计思想 We...

  • React进阶篇(八)react redux

    redux是参考Flux设计原则的一个管理数据流的库。 下图为redux的核心运作流程 redux 三大原则: 单...

  • redux 源码解读

    前言 redux并不局限于flux与react。redux 自身保持简洁以便适配各种场景,让社区发展出各种 red...

  • 有标题的文章

    React Redux 路由设计 - - React

网友评论

      本文标题:一个彻底改变Redux的简洁设计

      本文链接:https://www.haomeiwen.com/subject/cfypbqtx.html