iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >ReactMobx状态管理工具的使用
  • 704
分享到

ReactMobx状态管理工具的使用

ReactMobxReactMobx状态管理React状态管理 2023-02-06 12:02:42 704人浏览 安东尼
摘要

目录Mobx与redux的区别使用安装observable&&autorunaction使用装饰器写法runInAction(异步)Mobx与redux的区别 mob

Mobx与redux的区别

  • mobx写法偏向与oop
  • 对一份数据可以直接进行修改操作,不需要始终返回一个新的数据
  • 并非单一store,可以多个
  • redux默认使用js原生对象存储数据,而mobx使用可观察对象

使用

安装

npm i mobx@5

使用严格模式

configure({
    enforceActions:'always'
})

observable&&autorun

  • autorun用于监听值的改变
  • observable用于定义
import React,{Component} from 'react';
import {observable,autorun} from 'mobx';

//对于普通类型数据的监听
let observableNumber=observable.box(66)
let observableDesc=observable.box("学无止境...")
//第一次执行一次,之后被改变与它相关的会再次执行
autorun(()=>{
  console.log(observableNumber.get())
})
setTimeout(() => {
  observableNumber.set(11)
  observableDesc.set("爱学.")
}, 2000);

let myobj=observable.map({
  name:"碰磕",
  age:9999
})
autorun(()=>{
  console.log("对象name属性改变了"+myobj.get("name"))
})
class Zhuye extends Component{
  render() {
    return (  
      <div>
        Mobx
      </div>
    );
  };
};
export default Zhuye;

action

专门修改可观察的value

import {observable,autorun,action} from 'mobx'
const store=observable({
    isTabbarShow:true,
    list:[],
    cityName:"北京",
    changeShow(){
        this.isTabbarShow=true
    },
    changeHide(){
        this.isTabbarShow=false
    }
},{
    changeHide:action,
    changeShow:action//标记两个方法是action,专门修改可观察的value
})
export default store

然后在需要改变isTabbarShow的地方调用方法即可…

使用装饰器写法

import {observable,autorun,action} from 'mobx'
class Store{
    @observable isTabbarShow=true
    @observable list=[]
    @action changeShow(){
        this.isTabbarShow=true
    }
    @action changeHide(){
        this.isTabbarShow=false
    }
}
const store=new Store()
export default store

由于不支持装饰器写法,需要让它支持

1.安装依赖:

npm i @babel/core @babel/plugin-proposal-decorators @babel/preset-env

2.创建.babelrc{

    "presets": [
        "@babel/preset-env"
    ],
    "plugins": [
        [
            "@babel/plugin-proposal-decorators",
            {
                "legacy": true
            }
        ]
    ]
}

3.创建config-overrides.js

const path = require('path')
const { override, aDDDecoratorsLegacy } = require('customize-cra')
function resolve(dir) {
    return path.join(__dirname, dir)
}
const customize = () => (config, env) => {
    config.resolve.alias['@'] = resolve('src')
    if (env === 'production') {
        config.externals = {
            'react': 'React',
            'react-dom': 'ReactDOM'
        }
    }
    return config
};
module.exports = override(addDecoratorsLegacy(), customize())

4.安装依赖

npm i customize-cra react-app-rewired

5.修改package.JSON

----...
"scripts": {
    "start": "react-app-rewired start",
    "build": "react-app-rewired build",
    "test":  "react-app-rewired test",
    "eject": "react-app-rewired eject"
  },
----....

vscode需要配置

文件—首选项----设置-----搜索experimentalDecorators----勾上该设置

最后重新运行即可…

runInAction(异步)

异步请求时需要,在严格模式下

import axiOS from 'axios'
import {observable,autorun,action,runInAction, configure} from 'mobx'
configure({
    enforceActions:'always'
})
class Store{
    @observable isTabbarShow=true
    @observable list=[]
    @action changeShow(){
        this.isTabbarShow=true
    }
    @action changeHide(){
        this.isTabbarShow=false
    }
    @action getList(){
        axios({
            method:'GET',
            url:"https://m.maizuo.com/gateway?cityId=440300&ticketFlag=1&k=2005318",
            headers:{
                "X-Client-Info": '{"a":"3000","ch":"1002","v":"5.2.0","e":"1654433035923688551579649"}',
                "X-Host": "mall.film-ticket.cinema.list"
            }    
        }).then(res=>{
            runInAction(()=>{
                this.list=res.data.data.cinemas
            })
        })
    }
}
const store=new Store()
export default store

这样就可以修改this.list的了

Mobx的基本使用就大功告成了

到此这篇关于javascript Mobx状态管理工具的使用的文章就介绍到这了,更多相关JS Mobx内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: ReactMobx状态管理工具的使用

本文链接: https://www.lsjlt.com/news/194309.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作