前言:redux和mobx都是状态管理器,避免父级到子级再到子子级嵌套单向数据流,可以逻辑清晰的管理更新共享数据。(刷新页面redux储蓄数据即消失)
配置使用装饰器(使用高阶函数包装你的组件):
npm install  babel-plugin-transform-decorators-legacy --save-dev

.babelrc配置:

{
"presets": [
"react-app"
],
"plugins": [
[
"import",
{
"libraryName": "antd",
"style": true
}
],
"transform-decorators-legacy"
]
}

当使用react native的时候,下面这个预设可以代替 transform-decorators-legacy

"babel": {
"presets": [
"react-app",
"react-native-stage-0/decorator-support"
]
},
一.redux
redux.js文件:
// 定义变量
const CODE_CHANGE = 'CODE_CHANGE'
const NUMBER_LIST = 'NUMBER_LIST'
const ERROR_MSG = 'ERROR_MSG' // 初始化数据
const initState = {
industryNumber: storage.get('industryNumber'),
numberList: [],
msg: ''
} // reducer
export function isNumber(state = initState, action) {
switch (action.type) {
case CODE_CHANGE:
return { ...state, industryNumber: action.industryNumber }
case NUMBER_LIST:
return { ...state, numberList: action.numberList }
case ERROR_MSG:
return { ...state, msg: action.msg }
default:
return state
}
}

reducer.js文件:

import { combineReducers } from 'redux'
import { isNumber } from '/redux' export default combineReducers({ isNumber }) // 合并所有的reducer,并且返回

index.js入口文件:

import React from 'react'
import ReactDOM from 'react-dom'
import MainRouter from './Router'
// 引入redux
import { createStore, applyMiddleware, compose } from 'redux'
importthunk from 'redux-thunk' // 中间插件,增强dispatch功能,可异步加载action可接受函数参数
import { Provider } from 'react-redux' //redux组件,全部子级可以直接更新redux的state
import reducers from './reducer'
// 这里判断浏览器环境是否开启Redux DevTools的插件(chrome浏览器扩展插件应用商店下载)
const reduxDevtools = window.devToolsExtension ? window.devToolsExtension() : h => h //没有插件则返回空函数
const store = createStore(reducers, compose( applyMiddleware(thunk), reduxDevtools )) // 创建store
ReactDOM.render(
<Provider store={store}>
<MainRouter/> //路由
</Provider>,
document.getElementById('root')
)

某子组件:

import { connect } from 'react-redux'  // 装饰器

const fetchNumberList = () => {
return dispatch => { // 异步请求需要 dispatch => {}包裹
fetch('异步请求').then(res => {
if (res.code === 0) {
dispatch({ type: 'NUMBER_LIST', numberList: res.data })
}
})
}
} @connect(
state => state.isNumber, // 如果有多个reducer: state => ({ ..state.isNumber, ...state.someName })
{ fetchNumberList } // 一些之前写好的action方法
) class IndustryManagement extends Component {
constructor(props) {
super(props)
this.state= {
industryNumber: this.props.industryNumber && this.props.industryNumber[0], // 直接props引用redux的state
}
} btnChange() {
this.props.fetchNumberList() //经过装饰器的函数都可用props引用
} render() {
return (
<button onClick={ this.btnChange.bind(this) }>
)
}
}

二. mobx

这里推荐使用mobx-state-tree的写法,有兴趣的可去github上看用法,以下是传统写法:

store.js文件:
import { observable, action, runInAction } from 'mobx'
// runInAction接受异步action
class RootStore {
@observable userInfo = null //注册变量并监视变化(可以是引用类型值或者普通值) @observable number1 = 1 @observable number2 = 2 @computed getTotal(){
return this.number1 + this.number2 // 每当监视数据发生变化就会执行@computed
} @action.bound getData= async() => { // bound是为了绑定this上下文(箭头函数可不需要)
let res = await get('接口地址')
if (res.success) {
runInAction(() => { // runInAction函数可异步修改@observable数据
this.userInfo = res.data
})
}
}
} export default rootStore = new RootStore()

index.js入口文件:

import { Provider } from 'mobx-react'  // 与上文的redux的Provider相似
import rootStore from './store'
ReactDOM.render(
<Provider rootStore={rootStore}>
<MainRouter />
</Provider>,
document.getElementById('root')
)

某子组件:

import { observer, inject } from 'mobx-react'

@inject(({store, otherStore}) => ({ // 选择注入store(如果有多个store),如果不用inject函数可直接import store from '../store',组件中直接store.userInfo使用
userInfo: store.userInfo,
total: store.getTotal
})) @observer
class EmpRec extends Component {
constructor(props) {
super(props)
} render() {
return(
<div>
<div>this.props.userInfo</div>
<div>this.props.total</div>
</div>
)
}
}

.

redux VS mobx (装饰器配合使用)的更多相关文章

  1. react mobx 装饰器语法配置

    1.弹出项目配置 npm run eject 此处注意,若弹出项目配置失败,请先执行以下两行代码(我的项目执行上一句都会报错,所以都会执行) 1.git add . 2.git commit -m & ...

  2. 解决用creact-react-app新建React项目不支持 mobx装饰器模式导致报错问题 。

    创建react项目 create-react-app mobx-demo cd my-app npm run start 使用react-app-rewired npm install customi ...

  3. MobX基础 ----- 类的静态属性和装饰器

    当我们使用MobX的时候,首先要声明一个store, 用来保存状态,它的最基本的语法 如下: class Todo { @observable title = ""; @obser ...

  4. 关于Mobx中装饰器语法的环境配置

    1.弹出项目配置 npm run eject 此处注意,若弹出项目配置失败,请先执行以下两行代码(若没有安装git则请跳过,本人是在安装git的情况下解决问题的) 1.git add . 2.git ...

  5. create-react-app 构建的项目使用 mobx (说到底就是为了使用装饰器语法对 babel 做些配置

    在 create-react-app 命令行构建的 React 项目中使用 Mobx 会出现如下警告: Support for the experimental syntax 'decorators- ...

  6. redux和mobx比较(二)

    Redux Redux 是 JavaScript 状态容器,提供可预测化的状态管理. 三大核心 在 Redux 中,最为核心的概念就是 action .reducer.store 以及 state,那 ...

  7. Decorator - 利用装饰器武装前端代码

    历史 以前做后端时,接触过一点Spring,也是第一次了解DI.IOC等概念,面向切面编程,对于面向对象编程还不怎么熟练的情况下,整个人慌的一批,它的日志记录.数据库配置等都非常方便,不回侵入到业务代 ...

  8. redux和mobx入门使用

    redux和mobx入门使用 项目涉及技术 公共插件 create-react-app react-dom react-router react-router-dom react-hook redux ...

  9. python学习笔记-(八)装饰器、生成器&迭代器

    本节课程内容概览: 1.装饰器 2.列表生成式&迭代器&生成器 3.json&pickle数据序列化 1. 装饰器 1.1 定义: 本质上是个函数,功能是装饰其他函数—就是为其 ...

随机推荐

  1. js date扩展方法

    /* File Created: 四月 28, 2015 */ //日期加上天数得到新的日期 //dateTemp 需要参加计算的日期,days要添加的天数,返回新的日期,日期格式:YYYY-MM-D ...

  2. Scenes in Cocos2D

    https://www.makeschool.com/docs/?source=mgwu#!/cocos2d/1.0/scenes Scenes in Cocos2D In Cocos2D you h ...

  3. 資料視覺化:使用Python與JavaScript 简介和目录

    內容簡介 學習如何運用Python與JavaScript這組對超級強大的組合,處理手中的原始資料,建構出功能強大的互動式視覺化網站.在這一本以實務為主的書中,將告訴您如何善用Python和JavaSc ...

  4. [BZOJ2442][Usaco2011 Open]修剪草坪 dp+单调队列优化

    2442: [Usaco2011 Open]修剪草坪 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1118  Solved: 569[Submit] ...

  5. [BZOJ1634][Usaco2007 Jan]Protecting the Flowers 护花 贪心

    1634: [Usaco2007 Jan]Protecting the Flowers 护花 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 885  So ...

  6. [BZOJ1032][JSOI2007]祖码Zuma 区间dp

    1032: [JSOI2007]祖码Zuma Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 1105  Solved: 576 [Submit][S ...

  7. MySql笔记之修改MySQL提示符

    首先,了解下MYSQL提示符是神马东东 就是每次登陆mysql后出现的提示符 如果我们不喜欢这个提示符呢,那我们就改成我们喜欢的样子. 系统参数提示符 举个栗子 就改成相应的提示符了,那么可否随意改名 ...

  8. 树链剖分【p3038】[USACO11DEC]牧草种植Grass Planting

    表示看不太清. 概括题意 树上维护区间修改与区间和查询. 很明显树剖裸题,切掉,细节处错误T了好久 TAT 代码 #include<cstdio> #include<cstdlib& ...

  9. superviosrd进程管理

    supervisor进程管理器---------------------------1. 安装依赖yum install python-setuptools-devel 2. 安装supervisor ...

  10. SQL语句原理与高效SQL语句(转)

    做软件开发的programers,大部分都离不开跟数据库打交道,特别是erp开发的,跟数据库打交道更是频繁,存储过程动不动就是上千行,如果数据量大,人员流动大,那么还能保证下一段时间系统还能流畅的运行 ...