react_11

MobX

介绍

需求,组件0 改变了数据,其它组件也想获得改变后的数据,如图所示

这种多个组件之间要共享状态数据,useState 就不够用了,useContext 也不好用了

能够和 react 配合使用的状态管理库有

  • MobX

  • Redux

其中 Redux API 非常 难以使用,这里选择了更加符合人类习惯的 MobX,它虽然采用了面向对象的语法,但也能和函数式的代码很好地结合

文档
安装
复制代码
 npm install mobx mobx-react-lite

在异步操作里为状态属性赋值,需要放在 runInAction 里,否则会有警告错误

使用 store,所有使用 store 的组件,为了感知状态数据的变化,需要用 observer 包装,对应着图中 reactions

  • mobx 目前版本是 "mobx": "^6.10.2"

  • mobx-react-lite 目前版本是 "mobx-react-lite": "^4.0.5"

名词
  • Actions 用来修改状态数据的方法

  • Observable state 状态数据,可观察

  • Derived values 派生值,也叫 Computed values 计算值,会根据状态数据的改变而改变,具有缓存功能

  • Reactions 状态数据发生变化后要执行的操作,如 react 函数组件被重新渲染

使用

首先,定义一个在函数之外存储状态数据的 store,它与 useState 不同:

  • useState 里的状态数据是存储在每个组件节点上,不同组件之间没法共享

  • 而 MobX 的 store 就是一个普通 js 对象,只要保证多个组件都访问此对象即可

TypeScript 复制代码
import axios from "axios";
import { Student } from "../model/Student";
import { makeAutoObservable, runInAction, makeObservable, observable, action, computed } from 'mobx'
import R from "../model/R";
class StudentStore {
    //属性 对应状态数据(observable state),可观察
    @observable student: Student = { id: 0, name: 'zhangsan' }
    //对应着action方法(用来修改状态数据的方法)
//手动标识的时候使用 @action
    @action setName(name: string) {
        this.student.name = name
    }
    //对应着action方法(用来修改状态数据的方法)
    @action async fetch(id: number) {
        const resp = await axios.get<R<Student>>(`http://localhost:8080/api/students/${id}`)
        runInAction(() => {
            this.student = resp.data.data
        })
    }
    //派生值(derived values)或者叫计算值(computed values)会根据状态数据的改变而改变,计算值具有一个特性,
    //它具有缓存功能,比如第一次输入的是宋远桥,会计算出是宋大侠,第二次以及之后,如果宋远桥不变,那 
    //么displayName不会再执行了,它第一次执行的时候会把结果缓存起来
    @computed get displayName() {
        console.log('dispalyName 执行了')
        const first = this.student.name.charAt(0)
        if (this.student.sex === '男') {
            return first + '大侠'
        } else if (this.student.sex === '女') {
            return first + '女侠'
        }
        else {
            return ''
        }
    }
    //构造器
    constructor() {
//手动标识的时候使用
        makeObservable(this)
//自动使用的时候使用,如果不使用此代码,那么属性和方法就是普通属性和方法
        //makeAutoObservable(this)
    }
}
export default new StudentStore()

其中 makeAutoObservable 会

  • 将对象的属性 student 变成 Observable state,即状态数据

  • 将对象的方法 fetch 变成 Action,即修改数据的方法

  • 将 get 方法变成 Computed values

  • 手动标识的时候需要在在tsconifg.json 中加入配置

TypeScript 复制代码
{
  "compilerOptions": {
    // ...
    "experimentalDecorators": true
  }
}
相关推荐
yinuo2 小时前
前端跨页面通讯终极指南⑥:SharedWorker 用法全解析
前端
PineappleCoder6 小时前
还在重复下载资源?HTTP 缓存让二次访问 “零请求”,用户体验翻倍
前端·性能优化
拉不动的猪6 小时前
webpack编译中为什么不建议load替换ast中节点删除consolg.log
前端·javascript·webpack
李姆斯7 小时前
Agent时代下,ToB前端的UI和交互会往哪走?
前端·agent·交互设计
源码获取_wx:Fegn08957 小时前
基于springboot + vue健身房管理系统
java·开发语言·前端·vue.js·spring boot·后端·spring
闲谈共视7 小时前
基于去中心化社交与AI智能服务的Web钱包商业开发的可行性
前端·人工智能·去中心化·区块链
CreasyChan7 小时前
C# 反射详解
开发语言·前端·windows·unity·c#·游戏开发
JIngJaneIL8 小时前
基于Java+ vue智慧医药系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
阿蒙Amon9 小时前
JavaScript学习笔记:6.表达式和运算符
javascript·笔记·学习
hashiqimiya9 小时前
两个步骤,打包war,tomcat使用war包
java·服务器·前端