繁体   English   中英

react-router-dom 中的路由器在控制台中抛出错误,没有任何消息

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM