react-router-dom V6 路由传值及功能介绍


前言

React-router-dom已经升级到最新版本V6,先简单介绍一下v6版本发生了哪些改变


一、引入库文件

引入最新的reac-router-dom

yarn

$ yarn add react-router-dom@6

npm

$ npm install react-router-dom@6

二、使用步骤

1.首页引入Router

我这里引入的是HashRouter,还有一种BrowserRouter

import React from 'react';
import ReactDOM from 'react-dom';
import App from './App';
import { HashRouter } from 'react-router-dom';

ReactDOM.render(
  <React.StrictMode>
    <HashRouter>
      <App />
    </HashRouter>
  </React.StrictMode>,
  document.getElementById('root')
);

2.创建路由集中管理文件

index设置为true时,相当于一个默认的子路由
在v5中使用的是component,但是在v6中改成element

代码如下(示例):

import type { RouteObject } from 'react-router-dom'
import BaseLayout from '../layout/BaseLayout'
import About from '../pages/About'
import Home from '../pages/Home'
import AboutIndex from '../pages/About/Component/AboutIndex'
import AboutList from '../pages/About/Component/AboutList'
import Bussiness from '../pages/Bussiness'


const routes : RouteObject[] = [
    {
        path: "/",
        element: <BaseLayout/>, 
        children: [
            {
                index : true,
                element: <Home />
            },
            {
                path: "/about",
                element: <About />,
                children: [
                    { index : true, element: <AboutIndex />},
                    { path : "/about/:id", element :<AboutList />}
                ]
            },
            {
                path: "/bussiness",
                element: <Bussiness />,
            }
        ]
    },
    {
        path: "/sso",
        element: <div>1</div>
    }
]

export default routes

3.在App中使用useRoutes

import React from 'react';
import './App.css';
import { useRoutes } from 'react-router';
import routes from './route';

function App() {
  return (
    <div className="App">
      {useRoutes(routes)}
    </div>
  );
}

export default App;

4.在子页面中使用

<Outlet/ >相当于V5中的this.props.children,用于渲染子路由时显示嵌套 UI,如果父路由完全匹配,它将渲染子索引路由,如果没有索引路由,则不渲染。

import { Outlet ,useNavigate } from 'react-router';

const BaseLayout = () => {
   const navigate = useNavigate()
   const onMenuChange = (item : any) => {
       switch (item.key) {
           case "业务" : 
           navigate('/about')
           break
           case "关于" : 
           navigate('/bussiness')
           break
           default :
           navigate('/')
       }
   }

   return (
       <Layout>
           <Header style={{background:'#fff', position : 'fixed',zIndex:1,width:'100%',border:0}}>
               <Menu mode="horizontal" onClick={onMenuChange}>
                   <Menu.Item key="首页">首页</Menu.Item>
                   <Menu.Item key="业务">业务</Menu.Item>
                   <Menu.Item key="关于">关于</Menu.Item>
               </Menu>
           </Header>
           <Content style={{flex : '1',background:'#fff', padding: '0 50px', marginTop: 64 }}>
               <Outlet/>
           </Content>
           <Footer style={{ textAlign: 'center' }}>React Router Demo @2022</Footer>
       </Layout>
   )
}

export default BaseLayout

同时在V6中用useNavigate代替V5中的useHistory

// v5
history.push('/home');
history.replace('/home');
 
// v6
navigate('/home');
navigate('/home', {replace: true});

5.路由传值的方式

params参数

// 注册路由
<Route path="/about/:id" element={<AboutList />} />

// 通过navigate路由跳转
import { useNavigate } from "react-router-dom";

let navigate = useNavigate();
navigate('/about/6')

// 或者通过Link跳转
<Link to={{ pathname:`/about/6` }}>Child</Link>

// 通过useParams接受路由传值
import { useParams } from "react-router-dom";

const params = useParams();
console.log(params.id) // 6

search参数

// 注册路由
<Route path="/about/:id" element={<AboutList />} />

// 通过navigate路由跳转
import { useNavigate } from "react-router-dom";

let navigate = useNavigate();
navigate('/about/2?id=999')

// 或者通过Link跳转
<Link to={{ pathname:`/about/2?id=999` }}>Child</Link>

// 通过useParams接受路由传值
import { useSearchParams } from "react-router-dom";

const [searchParams, setSearchParams] = useSearchParams();

// 获取参数
searchParams.get('id')

// 判断参数是否存在
searchParams.has('id')

// 同时页面内也可以用set方法来改变路由
setSearchParams({"id":2})

console.log(searchParams.get('id')) // 999

state参数

// 通过navigate路由跳转
let navigate = useNavigate();
navigate('/about',{replace : true,state : { id : '666' }})

const location = useLocation()
console.log(location) 

/* 打印出来是如下结构
{
    "pathname": "/about",
    "search": "",
    "hash": "",
    "state": {
        "id": "666"
    },
    "key": "22tzhk2h"
} 
*/

在以前版本中,组件的props会包含一个match对象,在其中可以取到路径参数。但在最新的6.x版本中,无法从props获取参数。

并且,针对类组件的withRouter高阶组件已被移除。因此对于类组件来说,使用参数有两种兼容方法:

1.将类组件改写为函数组件
2.自己写一个HOC来包裹类组件,用useParams获取参数后通过props传入原本的类组件


总结

以上就是今天要讲的内容,下面是本文所用代码
链接: demo.

### 回答1: 要添加路由,首先需要在react-router-dom v6中导入BrowserRouter和Routes组件。然后在Routes组件中添加Route组件,并指定path和component属性,用于指定路由路径和对应的组件。例如: ``` import { BrowserRouter, Routes, Route } from 'react-router-dom'; import Home from './components/Home'; import About from './components/About'; function App() { return ( <BrowserRouter> <Routes> <Route path="/" element={<Home />} /> <Route path="/about" element={<About />} /> </Routes> </BrowserRouter> ); } ``` 在上面的示例中,当用户访问根路径时,会渲染Home组件,当访问/about路径时,会渲染About组件。需要注意的是,在v6中,使用element属性来指定要渲染的组件。 ### 回答2: 在使用React的项目中添加React Router Dom V6路由非常简单。首先,确保项目中已经安装了ReactReact Router Dom V6的依赖。 然后,在项目的入口文件中,导入`BrowserRouter`组件,并在`ReactDOM.render`方法中将根组件包装在`<BrowserRouter></BrowserRouter>`标签中。 接下来,在根组件中,导入`Routes`和`Route`组件,分别用于定义路由规则和具体的路由路径。 使用`Routes`组件,可以在其内部使用多个`Route`组件来定义不同的路由。每个`Route`都包含两个属性:`path`和`element`。`path`表示路由的路径,`element`表示对应的组件。 通过这种方式,可以轻松地添加不同路径的路由。例如,可以创建一个`Home`组件,并在路由中添加`path="/" element={<Home />}`。这样,当用户访问根路径时,将加载`Home`组件。 除了基本的路径匹配,React Router Dom V6还引入了`<Switch>`组件用于路由的排他性匹配。在`Switch`组件内部,可以使用`<Route>`组件来定义不同的路由。当匹配到第一个路由后,就不会继续匹配后面的路由。 此外,React Router Dom V6还提供了一些其他的组件和钩子,如`<Link>`组件用于创建链接,`useNavigate`钩子用于进行编程方式的导航等。 总结起来,通过使用React Router Dom V6的`<Routes>`和`<Route>`组件,可以轻松地添加路由路径和对应的组件。并且,通过`<Switch>`组件可以实现路由的排他性匹配。在需要进行导航操作时,可以使用`<Link>`组件或`useNavigate`钩子。 ### 回答3: 在 React 中使用 react-router-dom v6 添加路由非常简单。以下是一个简单的演示: 首先,确保已经安装了 react-router-dom v6: ```shell npm install react-router-dom@next ``` 然后,在你的 App.js(或其他根组件)中导入所需的库和组件: ```jsx import React from 'react'; import { BrowserRouter as Router, Routes, Route } from 'react-router-dom'; import Home from './Home'; import About from './About'; import NotFound from './NotFound'; const App = () => { return ( <Router> <Routes> <Route path="/" element={<Home />} /> <Route path="/about" element={<About />} /> <Route path="*" element={<NotFound />} /> </Routes> </Router> ); }; export default App; ``` 这里我们使用了 `<BrowserRouter>` 组件来为应用程序提供路由功能,然后使用 `<Routes>` 和 `<Route>` 组件来设置路由规则。 在 `<Routes>` 中,我们可以使用 `<Route>` 组件来定义具体的路由路径和对应的组件。`<Route>` 组件的 `path` 属性用于定义路由路径,`element` 属性用于指定该路径对应的组件。 在上面的例子中,我们将根路径 `/` 对应的组件设置为 `Home` 组件,路径 `/about` 对应的组件设置为 `About` 组件,而路径 `*` 对应的组件设置为 `NotFound` 组件(即未匹配到任何路由时显示的组件)。 当我们访问应用程序的不同路径时,react-router-dom v6 会根据路径自动加载相应的组件进行渲染。 希望这个简单的例子能够帮助你理解如何使用 react-router-dom v6 添加路由
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值