IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> React Router DOM 升级到 v6 后的一些报错信息 -> 正文阅读

[JavaScript知识库]React Router DOM 升级到 v6 后的一些报错信息

React Router DOM 升级到 v6 后的一些报错信息

之前在 React Router 的基本应用 讲了一下 react-router-dom 的一些基础用法。虽然那篇笔记写于去年,但是 react-router-dom 中有一些 breaking changes 导致原本的 API 已经被弃用。如果使用 npm i react-router-dom@5 的话,那么那篇笔记还是适用的,不过如果默认下载最新版本,那么程序就会抛出异常从而跑不起来。

报错 1:‘Switch’ is not exported from ‘react-router-dom’

那是因为 Switch 已经被弃用,被 Routes 所取代,这个问题就比较好解决:

import {
  BrowserRouter,
  Routes, // instead of "Switch"
} from "react-router-dom";

// ...

<BrowserRouter>
  <Routes>{/* 里面继续用 Route */}</Routes>
</BrowserRouter>;

报错 2:Property ‘exact’ does not exist on type

exact 在 v6 中也被移除了,并且 Route 的使用方法有些不同,如:

<Route path="/" element={<Home />} />

原本的 componentelement 所取代,传的值进去是一个。如果是这样的写法,那么这种写法就与使用 exact 相同。新版本的 react-router-dom 不会像之前的 Switch 一样遍历所有的 match 路径,而会返回第一个 match 的组件。

也就是说,可以去除 exact 直接使用路径:

<Routes>
  <Route path="/" element={<App />} />
  <Route path="expenses" element={<Expenses />} />
  <Route path="invoices" element={<Invoices />} />
</Routes>

另外,官方文档中提供了一种 nested 的写法:

  <BrowserRouter>
    <Routes>
      <Route path="/" element={<App />}>
        <Route path="expenses" element={<Expenses />} />
        <Route path="invoices" element={<Invoices />} />
      </Route>
    </Routes>
  </BrowserRouter>,

这种写法需要在外层添加一个 outlet

import { Outlet, Link } from "react-router-dom";

export default function App() {
  return (
    <div>
      <h1>Bookkeeper</h1>
      <nav
        style={{
          borderBottom: "solid 1px",
          paddingBottom: "1rem",
        }}
      >
        <Link to="/invoices">Invoices</Link> |{" "}
        <Link to="/expenses">Expenses</Link>
      </nav>
      <Outlet />
    </div>
  );
}

这样的写法,子组件,即 ExpensesInvoices 会替换掉 Outlet 而保留外层结构不变,算是另一种概念的 HOC 了。

需要嵌入变量的写法也需要使用 nested component 的写法:

<Route path="invoices" element={<Invoices />}>
  <Route path=":invoiceId" element={<Invoice />} />
</Route>

报错 2 中的代码来源于官方教程,也就是现在官方建议的使用方法。总体来说就是 nested nested 再 nested,或许这种写法能够更加直接间接地显示路径之间的关系吧。

参考

[1]: ‘Switch’ is not exported from ‘react-router-dom’

[2]: Property ‘exact’ does not exist on type

[3] : react-router/docs/getting-started/tutorial.md

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-23 10:46:47  更:2022-04-23 10:47:17 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 23:32:39-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码