我不知道为什么我得到这个错误,我在任何地方都找不到答案。我已经卸载了react-router-dom包并重新安装了它,但它仍然告诉我交换模块没有从react-router-dom导出。这是我的代码。

我得到的错误是:

试图导入错误:“Switch”没有从“react-router-dom”中导出。

Code

import React from 'react';
import './App.css';
import NavBar from './components/navbar.js';
import Footer from './components/footer.js';
import Home from './components/pages/homepage/home.js';
import { BrowserRouter as Router, Switch, Route, Link } from 'react-router-dom';

function App() {
  return (
    <Router>
      <div className="app-container">
        <NavBar />
        <Switch>
          <Route path="/home" component={Home} />
        </Switch>
        <Footer />
      </div>
    </Router>
  );
}

export default App;

当前回答

如果你正在使用react-router-dom v6,看起来Switch已经被Routes取代了。

其他回答

一个解决方案:

删除“node_modules”文件夹。在包装里。Json文件,更改react-router-dom版本(在我的情况下版本6)为“react-router-dom”:“^5.2.1”

然后在终端运行:

NPM install用于安装依赖项,然后运行 NPM开始重新启动

如果你正在使用react-router-dom v6,你必须改变Switch到Routes,如下面的例子所示:

而不是导入Switch, import {Switch,…} from 'react-router-dom';

进口航线 import{路由,…} from 'react-router-dom';

然后,不要使用component ={ComponentName},而是使用element={<ComponentName/>},如下所示:

import { Routes, Route, ...} from 'react-router-dom';
    .
    .
    .  
    <Routes>
      <Route exact path='/' element={<Home/>}></Route>
    </Routes>

在安装react-router-dom v6.0.2后,我得到了这个错误。

用路由替换交换机解决了这个问题:

import {BrowserRouter as Router, Route, Routes} from "react-router-dom";

我是这样解决的:

yarn add react-router-dom@5,3,0

如果你安装了react-router和react-router-dom v6 beta,就像这样卸载:

npm uninstall --save react-router react-router-dom

然后用这个安装:

npm install --save react-router react-router-dom

它将安装非beta版的最新版本。

然后我们只需要重新启动Visual Studio Code或任何你处理它的文本编辑器。