亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

react?中?mobx的使用案例詳解

 更新時(shí)間:2023年04月12日 14:22:34   作者:顧洛笙  
這篇文章主要介紹了react?中?mobx的使用案例詳解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

1.新建一個(gè)mobx.jsx文件

import { useContext } from "react"
import MyContext from '../../utils/Context'
//引入Observer監(jiān)聽組件  實(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文件

//倉庫文件  放所有的狀態(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í)行了');

            //異步操作會報(bào)警號 ,但是不會報(bào)錯(cuò)  解決方法:用runInaction包起來

            setTimeout(() => {
                //如果action里面用了異步 ,最好將你異步里面改變state的那步操作 用runInaction包起來 ,可以優(yōu)化一下
                runInAction(() => {
                    this.number++
                })

            }, 2000)
        },

        changeStr(v) {
            this.str = v;

        }

    })
}

let store = createDoubler()

//autorun 類似于監(jiān)聽  和可以寫在組件里面
autorun(() => {
    let a = store.number;
    console.log('autorun 執(zhí)行了');
})

//Reaction 指定你要監(jiān)聽的東西  和監(jiān)聽的作用一樣
reaction(() => store.number, () => {
    console.log('reaction 函數(shù)執(zhí)行了');
})


//導(dǎo)出一個(gè)對象
export default store

3.新建一個(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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Reactjs?+?Nodejs?+?Mongodb?實(shí)現(xiàn)文件上傳功能實(shí)例詳解

    Reactjs?+?Nodejs?+?Mongodb?實(shí)現(xiàn)文件上傳功能實(shí)例詳解

    今天是使用?Reactjs?+?Nodejs?+?Mongodb?實(shí)現(xiàn)文件上傳功能,前端我們使用?Reactjs?+?Axios?來搭建前端上傳文件應(yīng)用,后端我們使用?Node.js?+?Express?+?Multer?+?Mongodb?來搭建后端上傳文件處理應(yīng)用,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2022-06-06
  • 簡易的redux?createStore手寫實(shí)現(xiàn)示例

    簡易的redux?createStore手寫實(shí)現(xiàn)示例

    這篇文章主要介紹了簡易的redux?createStore手寫實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • React星星評分組件的實(shí)現(xiàn)

    React星星評分組件的實(shí)現(xiàn)

    評分插件在購物的應(yīng)用中經(jīng)??梢钥吹玫剑怯弥鴦e人的總是沒有自己寫的順手,本文就使用React實(shí)現(xiàn)星星評分組件,感興趣的可以了解一下
    2021-06-06
  • React如何避免子組件無效刷新

    React如何避免子組件無效刷新

    這篇文章主要介紹了React幾種避免子組件無效刷新的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 淺談react.js 之 批量添加與刪除功能

    淺談react.js 之 批量添加與刪除功能

    下面小編就為大家?guī)硪黄獪\談react.js 之 批量添加與刪除功能。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-04-04
  • 在React中強(qiáng)制重新渲染的4 種方式案例代碼

    在React中強(qiáng)制重新渲染的4 種方式案例代碼

    這篇文章主要介紹了在React中強(qiáng)制重新渲染的4 種方式,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2023-12-12
  • React?Flux與Redux設(shè)計(jì)及使用原理

    React?Flux與Redux設(shè)計(jì)及使用原理

    這篇文章主要介紹了React?Flux與Redux設(shè)計(jì)及使用,Redux最主要是用作應(yīng)用狀態(tài)的管理。簡言之,Redux用一個(gè)單獨(dú)的常量狀態(tài)樹(state對象)保存這一整個(gè)應(yīng)用的狀態(tài),這個(gè)對象不能直接被改變
    2023-03-03
  • 五分鐘教你了解一下react路由知識

    五分鐘教你了解一下react路由知識

    本文主要介紹了react路由知識,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 使用useEffect模擬組件生命周期

    使用useEffect模擬組件生命周期

    這篇文章主要介紹了使用useEffect模擬組件生命周期,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • React使用refs操作DOM方法詳解

    React使用refs操作DOM方法詳解

    React核心就在于虛擬DOM,也就是在React中不總是直接操作頁面真實(shí)的DOM元素,并且結(jié)合Diffing算法,可以做到最小化頁面重繪,有些時(shí)候不可避免的我們需要一種方法可以操作我們定義的元素標(biāo)簽,并作出對應(yīng)的修改。在React中提供了一種訪問DOM節(jié)點(diǎn)的方式,也就是這里的refs
    2022-11-11

最新評論