欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2023年10月13日 09:11:50   作者:明知山_  
這篇文章主要介紹了React使用Mobx6.x共享狀態(tài)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

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

文檔地址

安裝mobxmobx-react-lite
 

mobx-react-litemobx-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 的核心理念是 簡單、可擴展的狀態(tài)管理庫。比redux和react-redux方便許多

先create-react-app 構(gòu)建一個項目

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所以要這樣配置,也可以單獨在.babelrc文件中配置。

2者不能沖突,選其一

 "babel": {
    "presets": [
      "@babel/preset-env",
      "react-app"
    ],
    "plugins": [
      ["@babel/plugin-proposal-decorators", {
        "legacy": true
      }],
      ["@babel/plugin-proposal-class-properties", {
        "loose": true
      }]
    ]
  },

2.項目應(yīng)用

2.1一般先在src創(chuàng)建個store文件夾(定義狀態(tài)和創(chuàng)建實例)

2.2定義狀態(tài)并使其可觀察(狀態(tài)可以自定義創(chuàng)建)

import { observable, computed, action } from "mobx";
class OrderLine {
	// 被觀察者屬性
    @observable price = 0;
    @observable amount = 1;
    // 計算屬性  
    @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)建倉庫實例)

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實現(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的形式傳遞給目標組件
@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)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • ReactRouter的實現(xiàn)方法

    ReactRouter的實現(xiàn)方法

    這篇文章主要介紹了ReactRouter的實現(xiàn),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • 教你如何從 html 實現(xiàn)一個 react

    教你如何從 html 實現(xiàn)一個 react

    react是一個簡單的javascript UI庫,用于構(gòu)建高效、快速的用戶界面。它是一個輕量級庫,因此很受歡迎。接下來通過本文給大家分享從 html 實現(xiàn)一個 react的方法,一起看看吧
    2021-07-07
  • react中useState使用:如何實現(xiàn)在當(dāng)前表格直接更改數(shù)據(jù)

    react中useState使用:如何實現(xiàn)在當(dāng)前表格直接更改數(shù)據(jù)

    這篇文章主要介紹了react中useState的使用:如何實現(xiàn)在當(dāng)前表格直接更改數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • React中阻止事件冒泡的問題詳析

    React中阻止事件冒泡的問題詳析

    這篇文章主要給大家介紹了關(guān)于React中阻止事件冒泡問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用React具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 詳解React 條件渲染

    詳解React 條件渲染

    這篇文章主要介紹了React 條件渲染的相關(guān)資料,文中示例代碼非常詳細,幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • 基于React.js實現(xiàn)簡單的文字跑馬燈效果

    基于React.js實現(xiàn)簡單的文字跑馬燈效果

    剛好手上有一個要實現(xiàn)文字跑馬燈的react項目,然后ant-design上面沒有這個組件,于是只能自己手擼一個,文中的實現(xiàn)方法講解詳細,希望對大家有所幫助
    2023-01-01
  • 詳解React的回調(diào)渲染模式

    詳解React的回調(diào)渲染模式

    這篇文章主要介紹了詳解React的回調(diào)渲染模式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • react項目從新建到部署的實現(xiàn)示例

    react項目從新建到部署的實現(xiàn)示例

    這篇文章主要介紹了react項目從新建到部署的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • react+antd select下拉框?qū)崿F(xiàn)模糊搜索匹配的示例代碼

    react+antd select下拉框?qū)崿F(xiàn)模糊搜索匹配的示例代碼

    我們在開發(fā)過程中,經(jīng)常會出現(xiàn)下拉框數(shù)據(jù)很多得情況,本文主要介紹了react+antd select下拉框?qū)崿F(xiàn)模糊搜索匹配的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • react中關(guān)于useCallback的用法

    react中關(guān)于useCallback的用法

    這篇文章主要介紹了react中關(guān)于useCallback的用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06

最新評論