react-router学习笔记-路由的使用方法

我们公司用的是react-router5.0,查了一些资料其实和react-router4.0相差其实并不是很多,而且5.0的文档目前来看,很少,可能还不完善的吧,所以,这里着重介绍4.0的相关用法

首先react-router需要引入 react-router-dom这个包, 它和react-router这个包其实相差一个link标签,所以,我们常用react-router-dom这个包

安装: npm install --save react-router-dom

引入方式:

import { BrowserRouter as Router, Link, Route } from 'react-router-dom'

使用方式:

     <Router>
        <div>
          <nav>
            <ul>
              <li>
                <Link to="/">Home</Link>
              </li>
              <li>
                <Link to="/about?a=12">About</Link>
              </li>
            </ul>
          </nav>

          <Route path='/' exact component={Home}></Route>
          <Route path='/about' component={About}></Route>
        </div>
      </Router>

这里需要说明一下就是,这里的Router 这个分为两种 BrowserRouter 和HashRouter,有些教程直接使用Router,但是在我本地好像是无法生效的,也可能是版本更迭的问题,这里如果你使用的是4.0以上版本的,最好还是要带上 BrowserRouter as Router这句,如果你是服务端渲染的最好使用BrowserRouter,如果仅仅只作为静态页,HashRouter是个不错的选择

基础组件就是 Router, Route, Link

Router用于包裹Route,是应用的核心,一个应用基本上只包含一个

Route里面是要显示的相关组件,它分为两种,一种是直接使用Route,如果不给path,则默认展示这个链接到的组件,并且与其它已匹配的组件同时存在

另一种是switch,它里面的组件只存在一个,如果不写path,则默认展示这个组件

这样有一个好处,当存在大量path时候,switch默认渲染第一个匹配的路径,能节省一部分性能,而且当路由之间相互跳转时候,如果路由不存在可以跳转默认页面比如:404

Route组件渲染props有三种方式:component, render(), children,但是我们最常用的还是component,render

如果你有一个存在的组件,,而且你不想传递一个特定的组件内部变量信息的话,可以直接使用component,

如果你想渲染一个组件需要传递局部变量,可以使用render

const Home = () => <div>Home</div>;

const App = () => {
  const someVariable = true;

  return (
    <Switch>
      {/* these are good */}
      <Route exact path="/" component={Home} />
      <Route
        path="/about"
        render={props => <About {...props} extra={someVariable} />}
      />
      {/* do not do this */}
      <Route
        path="/contact"
        component={props => <Contact {...props} extra={someVariable} />}
      />
    </Switch>
  );
};

因为如果你不这样做,会引起期望之外的组件的卸载和重载。

Navigation

路由跳转:

NavLink相比Link多了一些样式调节,作用其实相差不大

另外如果想要重定向,可以使用<Redirect to="/">组件,这个组件如果存在,会默认执行跳转

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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 添加路由

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值