简洁的 React 状态管理 - Stamen

栏目: IOS · Android · 发布时间: 7年前

内容简介:说到 React 状态管理,必提的肯定是 Redux 与 MobX,2018 年,它们依然是最火热的状态管理工具,也有一些基于 Redux 的,如 dva、rematch 等,也有新的,如 mobx-state-tree,这里不对各个方案作评价。不评价但还是想吐槽:什么 provider, connections, actions, reducers, effects, dispatch, put, call, payload, @observable, @computed, @observer, @in

说到 React 状态管理,必提的肯定是 Redux 与 MobX,2018 年,它们依然是最火热的状态管理工具,也有一些基于 Redux 的,如 dva、rematch 等,也有新的,如 mobx-state-tree,这里不对各个方案作评价。

不评价但还是想吐槽:

什么 provider, connections, actions, reducers, effects, dispatch, put, call, payload, @observable, @computed, @observer, @inject…

一堆模板代码、各种概念、什么大哲学… 还有各种多余牛毛的 Api。

我只是想早点码完页面下班,早点下班健身、陪妹子…

所以,我想要这样的一个状态管理库:

  • 轻量 个人做移动端开发比较多
  • 简洁 没模板代码, 尽量少 api
  • 符合直觉 没复杂的概念, 给个 action 改 state 就好
  • 清晰 更易写出可维护和可读性好的代码
  • 高效 更高的开发效率,这很重要
  • Typescript 高度支持 state 和 action 的智能提示

我是个 实用主义者开发效率代码可维护性和可读性开发体验 大于各种什么范式、各种理论,也不需要装纯,重要的是可以快速处理业务,产生价值,早点下班打王者。

有一天,我看到了 mobx 作者的 immer, 我感觉使用 immer, 可以实现一个我理想中的状态管理方工具,所以造了一个轮子,叫 stamen , 他有什么特点呢,我说过想要的就是。

如果有什么 核心特点 的话,那应该是 “ 简洁 “,这里指的是使用者写代码时简洁,可以专注于业务,而不是自身源代码简洁,把问题留给使用者。

用法比较点单:

import React from 'react';
import { render } from 'react-dom';
import { createStore } from 'stamen';

const { consume, mutate } = createStore({ count: 1 });

const App = () => (
  <div>
    <span>{consume(state => state.count)}</span>
    <button onClick={() => mutate(state => state.count--)}>-</button>
    <button onClick={() => mutate(state => state.count++)}>+</button>
  </div>
);

render(<App />, document.getElementById('root'));

只有 state 和 action 没有其他概念, 只有一个 api:

const { consume, mutate } = createStore({ count: 1 });

更用法可以看:

Github: https://github.com/forsigner/stamen

文档: http://forsigner.com/stamen-zh-cn


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

JavaScript & jQuery

JavaScript & jQuery

David Sawyer McFarland / O Reilly / 2011-10-28 / USD 39.99

You don't need programming experience to add interactive and visual effects to your web pages with JavaScript. This Missing Manual shows you how the jQuery library makes JavaScript programming fun, ea......一起来看看 《JavaScript & jQuery》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具