商店'someStore'不可用!确保它是由某个提供商提供的

Eng*_*110 4 typescript reactjs mobx-react

我正在尝试建立一个新的项目React,Typescript和MobX.

出于某种原因,我无法让MobX工作.这是一段相对简单的代码,但它给了我这个错误.

未捕获的错误:MobX注入器:商店'appState'不可用!确保它是由某个提供商提供的

这是我的代码:

AppState.ts

import {observable} from "mobx"
import {observer} from "mobx-react"

export class AppState {
    @observable public greeting = "hello World"
}
Run Code Online (Sandbox Code Playgroud)

index.tsx

import * as React from "react"
import * as ReactDOM from "react-dom"
import { Provider } from "mobx-react"
import { Router, Route, Switch } from "react-router"
import { createBrowserHistory } from "history"
import MuiThemeProvider from "material-ui/styles/MuiThemeProvider"
"./containers/BookingStep/BookingStepContainer";
import { TestContainer } from "./containers/TestContainer";
import { AppState } from "./store/AppState";

const history = createBrowserHistory()

ReactDOM.render(
  <Provider store={AppState}>
    <Router history={history}>
      <Switch>
        <MuiThemeProvider>
          <div>
            <Route path="/test" component={TestContainer} />
          </div>
        </MuiThemeProvider>
      </Switch>
  </Router>
</Provider>,
document.getElementById("root"))
Run Code Online (Sandbox Code Playgroud)

TestContainer.tsx

import * as React from "react"
import { inject } from "mobx-react"
import { AppState } from "../store/AppState"

export interface ITestContainerProps {
    appState?: AppState
}

@inject("appState")
export class TestContainer extends React.Component<ITestContainerProps, any> {

    public render() {
        const { children, appState } = this.props

        return (
            <div>
                {appState.greeting}
            </div>
        )
    }
}
Run Code Online (Sandbox Code Playgroud)

任何人都可以指出我错过了什么?

eth*_*day 8

你要求注射器寻找一个名为的商店appState,但你给的Provider是一个名为的商店store.看起来您需要更改此行:

<Provider store={AppState}>
Run Code Online (Sandbox Code Playgroud)

至:

<Provider appState={AppState}>
Run Code Online (Sandbox Code Playgroud)