我使用 react js 创建了一个应用程序,然后将其部署到服务器,但是当我访问它时,我发现了一个没有错误消息的空白页面。 我在 stackoverflow 中搜索了 google 和其他相关问题,并尝试了他们的解决方案,但我仍然有空白页。 然后我将 BrowserRouter 更改为 HashRouter 在这种情况下它可以工作,但在某些时候出现以下错误: error message image
(我想我可以通过对代码进行一些更改来修复它)
但我不想使用 HashRouter , 有没有其他可能使用 BrowserRouter 使其工作(没有空白页)?
package.json :
{
"name": "flowdia_react_version",
"homepage": ".",
"version": "0.1.0",
"private": true,
"dependencies": {
"@testing-library/jest-dom": "^5.11.4",
"@testing-library/react": "^11.1.0",
"@testing-library/user-event": "^12.1.10",
"react": "^17.0.2",
"react-dom": "^17.0.2",
"react-router-dom": "^5.2.0",
"react-scripts": "4.0.3",
"serve": "^12.0.0",
"web-vitals": "^1.0.1"
},
"scripts": {
"start": "react-scripts start",
"build": "react-scripts build",
"test": "react-scripts test",
"eject": "react-scripts eject"
},
"eslintConfig": {
"extends": [
"react-app",
"react-app/jest"
]
},
"browserslist": {
"production": [
">0.2%",
"not dead",
"not op_mini all"
],
"development": [
"last 1 chrome version",
"last 1 firefox version",
"last 1 safari version"
]
}
}
index.js :
import React from "react";
import ReactDOM from "react-dom";
import App from "./App";
import { BrowserRouter as Router } from "react-router-dom";
ReactDOM.render(
<React.StrictMode>
<Router forceRefresh={true} >
<App />
</Router>
</React.StrictMode>,
document.getElementById("root")
);
app.js:
import "./dist/css/style.css";
import { Switch, Route } from "react-router-dom";
import Questions from "./components/questions/Questions";
import StartPage from "./components/StartPage";
import Output from "./components/Output";
import HomeCare from "./components/HomeCare";
const App = () => {
return (
<Switch>
<Route path="/" exact children={<StartPage />} />
<Route path="/questions" children={<Questions />} />
<Route path="/output" children={<Output />} />
<Route path="/home-care" children={<HomeCare />} />
</Switch>
);
};
export default App;