react?中?mobx的使用案例詳解
1.新建一個(gè)mobx.jsx文件
import { useContext } from "react"
import MyContext from '../../utils/Context'
//引入Observer監(jiān)聽(tīng)組件 實(shí)現(xiàn)數(shù)據(jù)和視圖層的雙向改變
import { Observer } from 'mobx-react'
const Mobx = () => {
//hook有規(guī)則 useContext只能在組件里面用
const store = useContext(MyContext);
return (
<Observer>
{() => {
return (
<div>
<p>我是Mobx的應(yīng)用</p>
<ul>
<li>mobx組件</li>
<li>使用mobx 的數(shù)據(jù) msg === {store.msg}</li>
<li>使用mobx 的數(shù)據(jù) number === {store.number}</li>
<li>使用mobx 的數(shù)據(jù) str === {store.str}</li>
<li>mobx的計(jì)算屬性 1 : {store.double}</li>
<li>mobx的計(jì)算屬性 2 : {store.tatal}</li>
<button onClick={() => { store.changeNum() }}>改變munber</button>
<button onClick={()=> {store.changeStr('柳林')}}>改變str</button>
</ul>
</div>
)
}}
</Observer>
)
}
export default Mobx
2.新建一個(gè)store文件夾 ---- 下面一個(gè)index.js文件
//倉(cāng)庫(kù)文件 放所有的狀態(tài). 數(shù)據(jù)
import { makeAutoObservable, runInAction, autorun, reaction } from "mobx"
function createDoubler(value) {
return makeAutoObservable({
//這是放狀態(tài)的
msg: '我是公共數(shù)據(jù)',
number: 20,
str: '程小小',
value,
//關(guān)鍵字 get 就代表這是一個(gè)計(jì)算屬性 函數(shù)內(nèi)部必須要返回一個(gè)值
get double() {
return this.number * 2
},
//get 計(jì)算屬性可以有多個(gè)
get tatal() {
return this.str + this.number
},
//actions 所有的方法 方法內(nèi)部 內(nèi)部可以放異步操作
changeNum() {
console.log('changeNum 函數(shù)執(zhí)行了');
//異步操作會(huì)報(bào)警號(hào) ,但是不會(huì)報(bào)錯(cuò) 解決方法:用runInaction包起來(lái)
setTimeout(() => {
//如果action里面用了異步 ,最好將你異步里面改變state的那步操作 用runInaction包起來(lái) ,可以優(yōu)化一下
runInAction(() => {
this.number++
})
}, 2000)
},
changeStr(v) {
this.str = v;
}
})
}
let store = createDoubler()
//autorun 類似于監(jiān)聽(tīng) 和可以寫(xiě)在組件里面
autorun(() => {
let a = store.number;
console.log('autorun 執(zhí)行了');
})
//Reaction 指定你要監(jiān)聽(tīng)的東西 和監(jiān)聽(tīng)的作用一樣
reaction(() => store.number, () => {
console.log('reaction 函數(shù)執(zhí)行了');
})
//導(dǎo)出一個(gè)對(duì)象
export default store3.新建一個(gè)context.jsx文件
//把 創(chuàng)建context提出去
import { createContext } from 'react'
const MyContext = createContext()
export default MyContext到此這篇關(guān)于react 中 mobx的使用案例詳解的文章就介紹到這了,更多相關(guān)react mobx使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Reactjs?+?Nodejs?+?Mongodb?實(shí)現(xiàn)文件上傳功能實(shí)例詳解
今天是使用?Reactjs?+?Nodejs?+?Mongodb?實(shí)現(xiàn)文件上傳功能,前端我們使用?Reactjs?+?Axios?來(lái)搭建前端上傳文件應(yīng)用,后端我們使用?Node.js?+?Express?+?Multer?+?Mongodb?來(lái)搭建后端上傳文件處理應(yīng)用,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2022-06-06
簡(jiǎn)易的redux?createStore手寫(xiě)實(shí)現(xiàn)示例
這篇文章主要介紹了簡(jiǎn)易的redux?createStore手寫(xiě)實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
React星星評(píng)分組件的實(shí)現(xiàn)
評(píng)分插件在購(gòu)物的應(yīng)用中經(jīng)??梢钥吹玫?,但是用著別人的總是沒(méi)有自己寫(xiě)的順手,本文就使用React實(shí)現(xiàn)星星評(píng)分組件,感興趣的可以了解一下2021-06-06
在React中強(qiáng)制重新渲染的4 種方式案例代碼
這篇文章主要介紹了在React中強(qiáng)制重新渲染的4 種方式,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-12-12
React?Flux與Redux設(shè)計(jì)及使用原理
這篇文章主要介紹了React?Flux與Redux設(shè)計(jì)及使用,Redux最主要是用作應(yīng)用狀態(tài)的管理。簡(jiǎn)言之,Redux用一個(gè)單獨(dú)的常量狀態(tài)樹(shù)(state對(duì)象)保存這一整個(gè)應(yīng)用的狀態(tài),這個(gè)對(duì)象不能直接被改變2023-03-03

