React - mobx

项目搭建

搭建全局脚手架
npm install -g create-react-app
在 cra 中使用非 eject 方式启用 decorator
初始化
npx create-react-app mobx-demo
安装改变 create-react-app 中 webpack 配置插件
yarn add -D react-app-rewired customize-cra @babel/plugin-proposal-decorators mobx mobx-react
在项⽬根⽬录创建 config-overrides.js 并写⼊以下内容:
const { override, addDecoratorsLegacy } = require("customize-cra")
module.exports = override(
	addDecoratorsLegacy()
)
修改 package.json ⽂件中 scripts 脚本
"scripts": {
   "start": "react-app-rewired start",
   "build": "react-app-rewired build",
   "test": "react-app-rewired test",
   "eject": "react-app-rewired eject"
 },
启动
yarn start
mbox使用步骤
初始化 mobx 容器仓库
index.js
// 使用 mobx 6 更新数据后,数据有变动,但不会自动进行更新则需要加 ··makeObservable··
import {observable, action, makeObservable} from 'mobx'

class Store·
 constructor () {
   makeObservable(this)
 }
 @observable count = 0
 @action.bound increment () {
   this.count ++
 }
}
在组件中使用 mobx 容器状态
在组件是发起 action 修改容器状态
import {inject, observer, Provider} from 'mobx-react'

@inject('store')
@observer
class CountIndex extends React.Component {
 constructor (props) {
   super(props)
 }
 render () {
   const { store } = this.props
   return (
     <div>
       <p>{store.count}</p>
       <button onClick={store.increment}>+</button>
     </div>
   )
 }
}
使用 mobx-react 与 react 关联
<Provider store={new Store()}><CountIndex /></Provider>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值