React使用Mobx6.x共享狀態(tài)問題
React使用Mobx6.x共享狀態(tài)

安裝mobx、mobx-react-lite
mobx-react-lite是mobx-react的輕量級版本
yarn add mobx mobx-react-lite
在src目錄下新建store文件夾,新增count.js文件
count為共享的數(shù)據(jù)addCount為共享的方法
import { makeAutoObservable } from "mobx"
export default makeAutoObservable({
count: 0,
addCount() {
this.count++
}
})jsx文件引入
被observer 包裹的組件可以監(jiān)聽store的值并改變
import { useEffect } from 'react'
import countStore from '@/store/count'
import { observer } from "mobx-react-lite"
export default observer(() => {
//監(jiān)聽mobx觸發(fā)事件
useEffect(() => {
console.log(countStore.count)
}, [countStore.count])
return (
<div>
<div>count為:{countStore.count}</div>
<button onClick={() => countStore.addCount()}>+1</button>
</div>
)
})react-Mobx基本使用
十分鐘交互式的 MobX + React 教程
mobx 的核心理念是 簡單、可擴(kuò)展的狀態(tài)管理庫。比redux和react-redux方便許多
先create-react-app 構(gòu)建一個項(xiàng)目
1.裝包
1.1安裝mobx mobx-react
npm install mobx mobx-react -S
1.2安裝裝飾器裝包搭配依賴去解析(可選),裝飾器作用>代碼更簡潔
npm i --save-dev babel-plugin-transform-decorators-legacy
1.3裝完依賴,然后json 文件中配置啟用,現(xiàn)在采用的是babel7所以要這樣配置,也可以單獨(dú)在.babelrc文件中配置。
2者不能沖突,選其一
"babel": {
"presets": [
"@babel/preset-env",
"react-app"
],
"plugins": [
["@babel/plugin-proposal-decorators", {
"legacy": true
}],
["@babel/plugin-proposal-class-properties", {
"loose": true
}]
]
},2.項(xiàng)目應(yīng)用
2.1一般先在src創(chuàng)建個store文件夾(定義狀態(tài)和創(chuàng)建實(shí)例)
2.2定義狀態(tài)并使其可觀察(狀態(tài)可以自定義創(chuàng)建)
import { observable, computed, action } from "mobx";
class OrderLine {
// 被觀察者屬性
@observable price = 0;
@observable amount = 1;
// 計(jì)算屬性
@computed
get total() {
return this.price * this.amount;
}
@observable length = 2;
@computed
get squared() {
return this.length * this.length;
}
set squared(value) {
// 這是一個自己的動作,不需要注解
this.length = Math.pow(2, value);
}
//觸發(fā)的動作
@action.bound
resize() {
this.price++;
}
}
export default OrderLine;2.3 在store目錄創(chuàng)建index.js (創(chuàng)建倉庫實(shí)例)
import OrderLine from "./OrderLine";
class Stores {
constructor() {
this.orderLine = new OrderLine(); //每次創(chuàng)建的狀態(tài)在這里注入
}
}
export default new Stores();2.4 類似react-redux一樣,MOBX也有mobx-react實(shí)現(xiàn)mobx與react的鏈接,所以在根組件中使用注入這個倉庫。
import React, { Component } from "react";
import MobxTest from "./Components/Mobox/MobxTset01";
import stores from "./Components/Mobox/store";
import { Provider } from "mobx-react";
class App extends Component {
render() {
return (
<Provider {...stores}>
<MobxTest />
</Provider>
);
}
}
export default App;2.5 創(chuàng)建視圖以響應(yīng)狀態(tài)的變化,在別的組件中使用注解的方式使用
import React, { Component } from "react";
import { observer, inject } from "mobx-react";
import { observable } from "mobx";
//@inject() 將組件鏈接到 stores,以props的形式傳遞給目標(biāo)組件
@inject("orderLine")
@observer //觀察者
class MobxTest extends Component {
constructor(props) {
super(props);
this.state = {};
}
componentWillMount() {
console.log("componentWillMount方法");
}
onReset() {
this.props.orderLine.resize(); //狀態(tài)中定義的方法從而改變倉庫中的值
}
render() {
//通過發(fā)現(xiàn)倉庫中定義的值,和方法都可以通過props屬性拿到注入orderLine所有屬性和方法
console.log(this.props,'this.props');
console.log(this.props.orderLine.amount);
return (
<div>
<p>{this.props.orderLine.total}</p>
{/* <p>{this.secondsPassed}</p> */}
<p>{this.props.orderLine.total}</p>
<button onClick={this.onReset.bind(this)}>按鈕</button>
</div>
);
}
}
export default MobxTest;效果圖 :

Mobx官網(wǎng)傳送門:https://cn.mobx.js.org/
總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
教你如何從 html 實(shí)現(xiàn)一個 react
react是一個簡單的javascript UI庫,用于構(gòu)建高效、快速的用戶界面。它是一個輕量級庫,因此很受歡迎。接下來通過本文給大家分享從 html 實(shí)現(xiàn)一個 react的方法,一起看看吧2021-07-07
react中useState使用:如何實(shí)現(xiàn)在當(dāng)前表格直接更改數(shù)據(jù)
這篇文章主要介紹了react中useState的使用:如何實(shí)現(xiàn)在當(dāng)前表格直接更改數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08
基于React.js實(shí)現(xiàn)簡單的文字跑馬燈效果
剛好手上有一個要實(shí)現(xiàn)文字跑馬燈的react項(xiàng)目,然后ant-design上面沒有這個組件,于是只能自己手?jǐn)]一個,文中的實(shí)現(xiàn)方法講解詳細(xì),希望對大家有所幫助2023-01-01
react項(xiàng)目從新建到部署的實(shí)現(xiàn)示例
這篇文章主要介紹了react項(xiàng)目從新建到部署的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
react+antd select下拉框?qū)崿F(xiàn)模糊搜索匹配的示例代碼
我們在開發(fā)過程中,經(jīng)常會出現(xiàn)下拉框數(shù)據(jù)很多得情況,本文主要介紹了react+antd select下拉框?qū)崿F(xiàn)模糊搜索匹配的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01

