react-native+mobx

最近發(fā)現(xiàn)網(wǎng)上RN集成mobx各種花樣染厅,安裝各種過期插件玫芦,還都不對,我決定自己寫一個旨指,照著官網(wǎng)很簡單的集成好了。

轉(zhuǎn)載注明出處哦

安裝配置

  • @babel/plugin-proposal-decorators // 是為了適配裝飾器格式
  • mobx
  • mobx-react

我這里的版本是

"@babel/plugin-proposal-decorators": "7.8.3",
"mobx": "5.15.4",
"mobx-react": "6.1.8",

根目錄下創(chuàng)建.babelrc

{
    "presets": [
        "module:metro-react-native-babel-preset"
    ],
    "plugins": [
        [
            "@babel/plugin-proposal-decorators",
            {
                "legacy": true
            }
        ]
    ]
}

集成

  1. 創(chuàng)建一個/多個store
import { observable, action } from 'mobx'

/**
 * appstore為系統(tǒng)級store,用來處理app的常規(guī)數(shù)據(jù)
 */
// mobx 版本 < 6.0.0
class AppStore {
  @observable num = '我是隨機數(shù)'

  @observable count = 0

  @action
  setAppName(num: string) {
    this.num = num
  }

  @action
  addCount() {
    this.count++
  }
}

// mobx 版本>=6.0.0
class AppStore {
    constructor() {
        // 建議使用這種方式喳整,自動識別類型谆构,不需要再加前綴
        makeAutoObservable(this)
    }
  num = '我是隨機數(shù)'
  count = 0

  setAppName(num: string) {
    this.num = num
  }

  addCount() {
    this.count++
  }
}

export const appStore = new AppStore()

  1. 把多個store集中管理,便于初始化
import { appStore } from './store/app.store'

const mainStore = {
  appStore
}

export default mainStore

  1. 初始化(在入口處框都,比如app.tsx搬素, index.js)
import * as React from 'react'
import { NavigationContainer } from '@react-navigation/native'
import TabScreen from './src/page/tabs/tab.screen'
import { Provider } from 'mobx-react'
import mainStore from './src/mobx/mainStore'

export default function App() {
  return (
    <Provider {...mainStore}>
      <NavigationContainer>
        <TabScreen />
      </NavigationContainer>
    </Provider>
  )
}

  1. 使用
import React from 'react'
import { View, Text, Button } from 'react-native'
import { observer, inject } from 'mobx-react'

interface IP {
  appStore?: any
  navigation?: any
}
interface IS {}
@inject('appStore')
@observer
export default class HomeScreen extends React.Component<IP, IS> {
  render() {
    return (
      <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}>
        <Text>Home!</Text>
        <Text>{this.props.appStore.num}</Text>
        <Button
          title='去個人中心'
          onPress={() => {
            this.props.navigation.navigate('Profile')
          }}
        />
        <Button
          title='隨機數(shù)'
          onPress={() => this.props.appStore.setAppName(String(Math.random() * 100))}
        />
        <Button
          title={'點擊數(shù)' + this.props.appStore.count}
          onPress={() => this.props.appStore.addCount()}
        />
      </View>
    )
  }
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市魏保,隨后出現(xiàn)的幾起案子熬尺,更是在濱河造成了極大的恐慌,老刑警劉巖谓罗,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件粱哼,死亡現(xiàn)場離奇詭異,居然都是意外死亡檩咱,警方通過查閱死者的電腦和手機揭措,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來刻蚯,“玉大人蜂筹,你說我怎么就攤上這事÷梗” “怎么了艺挪?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我麻裳,道長口蝠,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任津坑,我火速辦了婚禮妙蔗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘疆瑰。我一直安慰自己眉反,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布穆役。 她就那樣靜靜地躺著寸五,像睡著了一般。 火紅的嫁衣襯著肌膚如雪耿币。 梳的紋絲不亂的頭發(fā)上梳杏,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天,我揣著相機與錄音淹接,去河邊找鬼十性。 笑死,一個胖子當(dāng)著我的面吹牛塑悼,可吹牛的內(nèi)容都是我干的劲适。 我是一名探鬼主播,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼厢蒜,長吁一口氣:“原來是場噩夢啊……” “哼霞势!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起郭怪,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤支示,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后鄙才,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體颂鸿,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年攒庵,在試婚紗的時候發(fā)現(xiàn)自己被綠了嘴纺。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡浓冒,死狀恐怖栽渴,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情稳懒,我是刑警寧澤闲擦,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響墅冷,放射性物質(zhì)發(fā)生泄漏纯路。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一寞忿、第九天 我趴在偏房一處隱蔽的房頂上張望驰唬。 院中可真熱鬧,春花似錦腔彰、人聲如沸叫编。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽搓逾。三九已至,卻和暖如春上炎,著一層夾襖步出監(jiān)牢的瞬間恃逻,已是汗流浹背雏搂。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工藕施, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人凸郑。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓裳食,卻偏偏與公主長得像,于是被迫代替她去往敵國和親芙沥。 傳聞我的和親對象是個殘疾皇子诲祸,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,629評論 2 354

推薦閱讀更多精彩內(nèi)容