我正在尝试使用由 npm run build 和 react-router 生成的静态 index.html 文件。tl;博士是; 我不想要客户端服务器,我希望通过打开位于构建文件夹中的 index.html 文件来加载应用程序,并且仍然让 BrowserRouter 能够在组件之间进行路由。目前,如果我在路由路径中排除了 'exact' 属性,页面将加载 'home' 组件,这意味着它知道它在某处,我只是不知道如何配置路由器来知道' C:/Users/Myself/Project/app/build/index.html' 等于 '/' 的路径,然后路由到每个组件。如果包含确切的props,它只会加载标准的 404 组件。我应该如何配置 BrouserRouter 基本名称和/或 package.json“主页”
我不想做的事情: - 为构建文件夹提供服务。- 配置 webpack - 可以从“ 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”(“/”)。
我愿意接受这是不可能的,但如上所述,能够从不精确的路径访问它使我相信我可以使它精确并且只是弄乱了路由配置