无法导航到 react-router-dom URL

grp*_*cMe 7 javascript reactjs react-router react-router-v4 react-router-dom

有一些关于 SO 的主题,比如这个建议更改 Webpack,而这个建议设置一个包罗万象的。

我正在使用react-router-dom三个路线;类似的故事,对这里剩余的问题,在/道路工程,但没有/cars/about不会。

import React, {Component} from 'react';
import {render} from 'react-dom';
import {BrowserRouter, Route, Switch, Link} from 'react-router-dom';


const Home = () => (
  <h1>Home</h1>
)

const Car = () => (
  <h1>Cars</h1>
)

const About = () => (
  <h1>About</h1>
)

render(
  <BrowserRouter>
    <Switch>
      <Route exact path="/" component={Home}/>
      <Route exact path="/cars" component={Car}/>
      <Route path="/about" component={About}/>
    </Switch>
  </BrowserRouter>,
  document.getElementById('container')
);
Run Code Online (Sandbox Code Playgroud)

我试过在我的 webpack 配置中添加一个publicPathhistoryApiFallback

module.exports = {
  entry: ['./src/index.jsx'],
  output: {
    path: path.resolve('public'),
    filename: 'bundle.js',
    publicPath: '/'
  },
  module: {
    loaders: [
      {test: /\.js$/,loader: 'babel-loader',exclude: /node_modules/},
      {test: /\.jsx$/,loader: 'babel-loader',exclude: /node_modules/}
    ]
  },
  devServer: {
    historyApiFallback: true
  }
}
Run Code Online (Sandbox Code Playgroud)

但是一旦我导航到,http://localhost:8080/cars我就会Cannot GET /cars在浏览器上收到一条消息,并出现大量与此类似的错误:

Refused to load the font 'data:font/woff;base64,d09GRgABAAAAAGz8ABEAAAAA09gAAQABAAAAAAAAAAAAAAAAAAAAAAAAAABHREVGAAABgAAAAC8AAAA0AsQC9UdQT1MAAAGwAAATuAAANLwBEyF1R1NVQgAAFWgAAAIWAAAEZqfk0PVPUy8yAAAXgAAAAFAAAABgaNCCw2NtYXAAABfQAAABkwAAAkQk8AV7Y3Z0IAAAGWQAAABiAAAAugGiQq9mcGdtAAAZyAAABZcAAAvNb3/BHGdhc3AAAB9gAAAACAAAAAgAAAAQZ2x5ZgAAH2gAAESvAAB8yu28l3FoZWFkAABkGAAAADYAAAA2BmibVWhoZWEAAGRQAAAAIAAAACQHMQRzaG10eAAAZHAAAAJDAAAEImBmMbxsb2NhAABmtAAAAhoAAAIaflxdR21heHAAAGjQAAAAIAAAACACjgzgbmFtZQAAaPAAAACdAAABKBQEL8lwb3N0AABpkAAAAsMAAAS9pi3QFXByZ...w76a3jVVUpJzXkBsRtNQoHWTV2mt2UusrulbnIrkvAXNBDFtTVIB8Uoau4pSruq4q7qq2dHpQADUAT0IJ5ra0yPUAfMACMFY6pOtegV/9D7UtTZx72tTeXI4JdcUXh7Pb67D7I/S05AwjAAiYsNie6WOwc4MiYCORSEx+ZExuCvQpiNSRmAdL8wDs2AslUOgp8HfnSYyfCYjrE7w8QDucyS0aXjH0zGk7FX991RgON6L7Qma6pQ+SzA0Qw1x9+HgNFtrBk+F9RsmDpTShvNJL4BDWtP8IAeAFj8N7BcCIoYiMjY1/kBsadHAwcDMkFGxnYnLZFMFgwMLAyaIE4DjzeHPYs+mzKLOIsrBxQoVA2VyZzFk0mWSawELfTPmEGAQYeBk4GNpBGTqCYgNM+BgcYhIgxM7hsVGHsCIzY4NARsZE5xWWjGoi3i6OBgZHFoSM5JAKkJBIIHHh8ORxZDNlUWSRZWHm0djD+b93A0ruRicFlA1vcRtYUFwBQJimV' because it violates the following Content Security Policy directive: "default-src 'self'". Note that 'font-src' was not explicitly set, so 'default-src' is used as a fallback.
Run Code Online (Sandbox Code Playgroud)

grp*_*cMe 4

通常情况下,我尝试自己解决这个问题 30 分钟后,感到沮丧并在 SO 上发帖;2分钟后我就明白了......!

我添加到文件中的配置webpack毫无意义;看到我正在使用我的文件express

catch-all方法是我需要的,但我做错了。你有两个选择。执行适当的“捕获所有”并将所有内容发送到 HTML 文件...

app.get('*', (req, res) => {
  res.sendFile(appRootPath + '/public/index.html');
});
Run Code Online (Sandbox Code Playgroud)

或者,如果像我一样,您只想发送特定端点,这样您仍然可以管理“其他事情”...

app.get('/react*', (req, res) => {
  res.sendFile(appRootPath + '/public/index.html');
});
Run Code Online (Sandbox Code Playgroud)

特别提及,因为这就是让我绊倒的原因,请确保你这样做/react*/而不是/react/*

然后我可以将我的路线更新为以下内容并直接浏览到它们......

render(
  <BrowserRouter>
    <Switch>
      <Route exact path="/react" component={Home}/>
      <Route exact path="/react/car" component={Car}/>
      <Route path="/react/about" component={About}/>
    </Switch>
  </BrowserRouter>,
  document.getElementById('container')
);
Run Code Online (Sandbox Code Playgroud)

这是我输入随机 URL 的示例