reactjs - 如何在静态index.html文件中使用react-router BrowserRouter

标签 reactjs routes react-router package.json static-html

我正在尝试使用 npm run build 生成的静态index.html 文件以及react-router。 tl;dr 是;我不需要客户端服务器,我希望通过打开位于构建文件夹中的 index.html 文件来加载应用程序,并且仍然让 BrowserRouter 能够在组件之间路由。目前,如果我在路由路径中排除“exact”属性,页面将加载“home”组件,这意味着它知道它在某个地方,我只是不知道如何配置路由器来知道“C:/Users/Myself/Project/app/build/index.html' 等于 '/' 的路径并路由到此后的每个组件。如果包含确切的 prop,它只会加载标准 404 组件。我应该如何配置 BrouserRouter 基本名称和/或 package.json“主页”,以便在页面最初打开时路由到 index.html-> 加载“home”组件?

我不想做的事情: - 提供构建文件夹。 - 配置网络包 - 可从“http://localhost:XXXX”访问该应用程序' - 更改为使用 HashRouter(我想访问 props.history.push)

在我看来,如果应用程序可以在不指定确切的情况下显示“home”组件,则意味着它可以在某些情况下到达它,而我只是没有正确指定索引路径是什么,即它在某个地方在那里像 ../project/build/index.html/somewhere

我已经将 package.json 配置为“homepage”:“.”,并指定了 BrowserRouter basename={'/build'}

我的浏览器路由器:

<BrowserRouter basename={'/build'}>
   <Routes />
</BrowserRouter>

我的routes.js 文件:

const Routes = (props) => {
  return (
    <div>
      <Switch>
        <Route path={routes.HOME} component={Home} />
        <Route render={(props) => <div>404 - Not Found</div>} />
      </Switch>

    </div>
  )
}

我的package.json:

{
  "name": "cra",
  "version": "0.1.0",
  "private": true,
  "homepage": ".",
  "dependencies": {
    "react": "^16.8.6",
    "react-dom": "^16.8.6",
    "react-redux": "^7.0.2",
    "react-router-dom": "^5.0.0",
    "react-scripts": "2.1.8",
    "redux": "^4.0.1",
    "redux-logger": "^3.0.6",
    "redux-thunk": "^2.3.0"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject"
  },
  "eslintConfig": {
    "extends": "react-app"
  },
  "browserslist": [
    ">0.2%",
    "not dead",
    "not ie <= 11",
    "not op_mini all"
  ],
  "devDependencies": {
    "node-sass": "^4.11.0"
  }
}

我希望最终结果将 c:/users/myself/project/app/build/index.html 设置为等于路由“home”(“/”)。

我愿意接受这是不可能的,但如上所述,能够从不精确的路径访问它让我相信我可以使其精确,而我只是搞乱了路由配置

最佳答案

If your application is hosted on a static file server, you need to use a <HashRouter> instead of a <BrowserRouter>.

FAQ.md#why-doesnt-my-application-render-after-refreshing

对于像 www.example.com/path/to/index.html 这样的网站,您需要尝试 <HashRouter> .

对于像 www.example.com 这样的网站, <BrowserRouter>可能会起作用。像 Nginx 这样的服务器需要额外的配置才能在刷新非根页面后正确呈现。

location / {
   try_files $uri /index.html;
}

关于reactjs - 如何在静态index.html文件中使用react-router BrowserRouter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55670845/

相关文章:

reactjs - React中如何从子组件获取值

reactjs - 将 Reactjs 变量传递给图像和链接标签

reactjs - 使用react-elm-components设置elm时出现问题

c# - ASP.NET MVC 模型嵌套路由

javascript - Express Generator app.use ('/login',用户)不拾取路线

reactjs - 在 react-router V4 中,我如何以编程方式设置查询字符串参数?

javascript - 通过 React 路由器的 <Redirect/> 组件在新选项卡中打开

javascript - 使用 react-router v4 重定向到登录页面

javascript - 为什么 Backbone.js 路由器不能在 iOS 中工作?

git - 使用 create-react-app 在 azure 上部署