私のコードはコンパイルされ実行されていますが、動作していません。私は何が間違っているのか分かりません。以下のコードサンプルは、それぞれのファイルから抜粋したものです。Typescript React ReactルータV4はルーティングされません
package.json
"dependencies": {
"@types/react": "^15.0.28",
"@types/react-dom": "^15.5.0",
"@types/react-router": "^4.0.11",
"react": "^15.6.1",
"react-dom": "^15.6.1",
"react-router": "^4.1.1",
"typescript": "^2.3.4"
},
index.tsx
import * as React from 'react';
import * as ReactDOM from 'react-dom';
import App from './App';
import Bids from './Bids';
import { MemoryRouter, Route, Switch} from 'react-router';
ReactDOM.render(
<MemoryRouter>
<Switch>
<Route exact path="/bids" component={() => <Bids />} />
<Route exact path="/" component={() => <App />} />
</Switch>
</MemoryRouter>
,
document.getElementById('root') as HTMLElement
);
と入札とアプリケーションの両方の単純な "Hello World" のレンダリング機能
class App extends React.Component<{}, null> {
render() {
問題とコンポーネントを反応させています私は、デフォルト以外のパスをレンダリングするプログラムを手に入れることができないということを持っています。
「http://localhost:3000/」に移動すると、私はAppコンポーネントを取得します。
"http://localhost:3000/bids"に移動すると、私はAppコンポーネントを取得します。
"http://localhost:3000/randomString"に移動すると、私はAppコンポーネントを取得します。
コードに「/ bids」が表示され、「/」が「入札」を指している)コードを切り替えると、入札単価コンポーネントはどのパスでも表示されます。
どのような考えですか?
あなたは '/'まず、その後、 '/ bids'を入れてみましたがありますか? – Li357
はい。動作をまったく変更しません。 –
なぜ 'MemoryRouter'ですか?ドキュメントからは、[アドレスバーの読み書きはできません](https://github.com/ReactTraining/react-router/blob/master/packages/react-router/docs/api/MemoryRouter.md )。 –