#reactjs #typescript #mobx
#reactjs #typescript #mobx
Вопрос:
Ниже приведен мой магазин, который будет извлекать observable units
из API с помощью loadUnits
метода, API работает хорошо, я также добавил console.log()
сюда, я вижу значение первого элемента.
import { ITutorialUnit } from "./../model/unit";
import { action, observable } from "mobx";
import { createContext } from "react";
import agent from "../api/agent";
class UnitStore {
@observable units: ITutorialUnit[] = [];
@observable title = "hello from mobx";
@observable loadingInitial = false;
@action loadUnits = () => {
this.loadingInitial = true;
agent.TutorialUnits.list()
.then(units => {
units.forEach((unit) => {
this.units.push(unit);
});
})
.then(() => console.log("from store:" this.units[0].content)) // I can see the data from this logging
.finally(() => (this.loadingInitial = false));
};
}
export default createContext(new UnitStore());
затем, когда я хочу использовать наблюдаемое units
в App.tsx
:
import React, { Fragment, useContext, useEffect, useState } from "react";
import { Container } from "semantic-ui-react";
import "semantic-ui-css/semantic.min.css";
import NavBar from "../../features/nav/NavBar";
import { ActivityDashboard } from "../../features/Units/dashboard/tutorialUnitDashboard";
import UnitStore from "../stores/unitStore";
import { observer } from "mobx-react-lite";
import { LoadingComponent } from "./LoadingComponent";
import agent from "../api/agent";
import { ITutorialUnit } from "../model/unit";
const App = () => {
const unitStore = useContext(UnitStore);
const units = unitStore;
useEffect(() => {
unitStore.loadUnits();
console.log("from App.tsx: " units); // will only log a undefined
}, [unitStore]);
if (unitStore.loadingInitial) {
return <LoadingComponent content="Loading activities..." />;
}
return (
<Fragment>
<NavBar />
<Container style={{ marginTop: "7em" }}>
<h1>{unitStore.title}</h1>
<ActivityDashboard />
</Container>
</Fragment>
);
};
export default observer(App);
Я не могу получить данные observable units
, но я могу получить данные другого observable title
, которые представляют собой просто строку, LoadingComponent также не работает.
пожалуйста, помогите мне!
Ответ №1:
Я понял это. версия Mobx должна быть ниже 6.0.0, я использую 5.10.1, и все в порядке.