使用React-Router时出现的错误

本文主要讨论在使用React-Router时遇到的问题,详细分析了Switch组件的作用,即防止多个路由组件同时显示。还提到了在Router6中,Routes替代了Switch,未使用Routes会导致错误,解决方案是在路由配置中添加Routes组件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用React-Router时出现的错误:


问题描述

在配置路由时出现的问题,关于 Router5 和 Router6的使用区别

bundle.js:38620 Uncaught Error: A <Route> is only ever to be used as the child of <Routes> element, never rendered directly. Please wrap your <Route> in a <Routes>.
    at invariant (bundle.js:38620:20)
    at Route (bundle.js:39415:11)
    at renderWithHooks (bundle.js:24114:22)
    at mountIndeterminateComponent (bundle.js:28690:17)
    at beginWork (bundle.js:30148:20)
    at HTMLUnknownElement.callCallback (bundle.js:12074:18)
    at Object.invokeGuardedCallbackDev (bundle.js:12123:20)
    at invokeGuardedCallback (bundle.js:12185:35)
    at beginWork$1 (bundle.js:34989:11)
    at performUnitOfWork (bundle.js:34163:16)


原因分析:

Switch的作用:

  • 通常情况下,path (路径) 和 coponent (组件) 是一一对应的关系。
  • 在默认的路由匹配规则中,如果不使用Switch,注册的所有路由都会和路径进行匹配,并且将匹配到的组件都显示出来。如下代码:如果输入路径为 /home 将会显示 Home 和 Hotel 两个组件。
  • Switch可以提高路由的匹配效率,一旦匹配上将不再继续向下匹配。
		 <Routes> 
                <Route path="/about" element={<About />}/>
                <Route path="/home" element={<Home />}/>
                <Route path="/home" element={<Hotel />}/>
              </Routes> 

Router6 中的Routes

Router6 中使用了 Routes 代替了 Switch,但是细微的差别是,Router5中不使用Switch是不会报错的。但是Router6中不使用Routes会报上述错误。这样修改的原因有待学习??


解决方案:

综上,解决方法当然是加上 Routes 呀

import React from "react";
import {BrowserRouter as Router, Routes, Route} from 'react-router-dom'
import Login from "./Login";
function Main(){
  return (
    <Router>
      <Routes>
       <Route path='/login' exact element={<Login/>} />
      </Routes>
    </Router>
  )
}
export default Main
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值