前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mobx的使用

Mobx的使用

作者头像
世间万物皆对象
发布2024-03-20 19:47:03
1360
发布2024-03-20 19:47:03
举报
文章被收录于专栏:start
安装语法

yarn add mobx yarn add mobx-react

类组件
一、在src下创建store文件创建index.js里引入以下代码
代码语言:javascript
复制
import { observable, computed, action, autorun, runInAction } from 'mobx';
// import {observable, computed, action} from 'mobx';
class Store {
  @observable tradeCfg = {
    'sadf': 'sadf'
  };
  @observable baseInfo = {};
  @observable callback = null;
  @observable token = [
    {
      "id": 1,
      "name": "YD"
    },
    {
      "id": 2,
      "name": "ETH"
    }
  ];
}
export default Store;
二、 在router.js里

1.引入import { Provider } from 'mobx-react'; 2.引入我们创建的store.js(多个或一个) 3.使用store需要new一下 new Store 因为store里是面向对象 4.用Provider进行包裹 {…stores}

@语法糖报错 解决办法安装下面两个命令 yarn add @babel/plugin-proposal-decorators yarn add @babel/plugin-proposal-class-properties

安装完成后把package.json里的babel里的presets替换掉 "presets": [ ["react-app"], ["@babel/preset-react"] ], "plugins": [ ["@babel/plugin-proposal-decorators", {"legacy": true }], ["@babel/plugin-proposal-class-properties", { "loose" : true }] ]

三、任意子页面上使用mobx

1.引入import { withRouter } from 'react-router-dom';

2.引入import { observer, inject } from 'mobx-react';

3.在类组件上引入@withRouter @inject('Fstore') @observer 4.在render下打印props

函数组件

1.引入import { withRouter } from 'react-router-dom' 2.引入import { observer, MobXProviderContext } from 'mobx-react' 3.自定义一个函数 作用是:相当于把React.useContext(MobXProviderContext).Fstore进行封装 减少大量的.操作 function useStores(name) { return React.useContext(MobXProviderContext)[name] } 4. 用withRouter包裹observer包裹组件 例如: withRouter(observer(Mobx)) 等同于 @withRouter @inject('Fstore') @observer

调用方式 const { tradeCfg } = useStores('Fstore')

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-03-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装语法
  • 类组件
    • 一、在src下创建store文件创建index.js里引入以下代码
      • 二、 在router.js里
        • 三、任意子页面上使用mobx
        • 函数组件
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档