[英]Router in react-router-dom throws an error in the console with no message
我目前正在构建一个应用程序,并且遇到了来自 Route 组件的奇怪的 react-router-dom 错误。
我不确定为什么在 webpack 中启用“devtool:'inline-source-map'”时会收到生产错误消息,但基本上我不确定是什么引发了错误。 这是我当前的前端设置
import React from 'react';
import { render } from 'react-dom';
import { BrowserRouter as Router, Route } from 'react-router-dom';
import HomePage from './components/Homepage';
render(
<Router>
<div> Hello from react </div>
<Route path="/" element={<HomePage />} />
</Router>,
document.getElementById('app-portal')
);
并通过注释掉<Route path="/" element={<HomePage />} />
该应用程序可以正常工作,但我当然需要 Route 才能为该应用程序工作...
这是我的 package.json 依赖项。
"dependencies": {
"axios": "^0.26.1",
"express": "^4.17.3",
"html-webpack-plugin": "^5.5.0",
"nodemon": "^2.0.15",
"path": "^0.12.7",
"react": "^18.0.0",
"react-dom": "^18.0.0",
"react-router": "^6.3.0",
"react-router-dom": "^6.3.0"
},
"devDependencies": {
"@babel/cli": "^7.7.4",
"@babel/core": "^7.12.10",
"@babel/plugin-transform-runtime": "^7.8.3",
"@babel/preset-env": "^7.16.11",
"@babel/preset-react": "^7.16.7",
"@babel/preset-stage-2": "^7.8.3",
"@babel/register": "^7.7.4",
"assert": "^2.0.0",
"babel-core": "^7.0.0-bridge.0",
"babel-eslint": "^8.2.3",
"babel-loader": "^8.2.5",
"babel-plugin-styled-components": "^1.12.0",
"css-loader": "^6.7.1",
"eslint": "^4.19.1",
"eslint-plugin-react": "^7.8.2",
"file-loader": "^6.2.0",
"morgan": "^1.10.0",
"style-loader": "^3.3.1",
"webpack": "^5.72.0",
"webpack-cli": "^4.9.2"
},
有人遇到过类似的问题吗? 如果是这样,它是如何解决的?
正如评论中所指出的,该应用程序是一个生产版本,因此调试信息被删除了。 但是在错误日志中,那些是链接,所以您实际上可以单击它并查看某种形式的代码,看看问题出在哪里,代码抛出错误。
根据您的代码,尽管我假设错误是您没有将Route
组件渲染到Routes
组件中。 Routes
组件负责处理路由路径匹配,并且在react-router-dom@6
中是必需的。
import React from 'react';
import { render } from 'react-dom';
import { BrowserRouter as Router, Routes, Route } from 'react-router-dom';
import HomePage from './components/Homepage';
render(
<Router>
<div>Hello from react</div>
<Routes>
<Route path="/" element={<HomePage />} />
</Routes>
</Router>,
document.getElementById('app-portal')
);
就我而言,当我将我的应用程序发布到 github-page 时,发生了这个错误。 原因是我的错误。 我设置了两次<BrowserRouter />
组件。 首先,在 index.tsx
root.render(
<BrowserRouter basename={`${process.env.PUBLIC_URL}`}>
<App />
</BrowserRouter>
);
并在 app.tsx 中进行设置,然后设置<BrowserRouter />
。 所以,当我在 app.tsx BrowserRouter 组件中删除时,一切正常。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.