首页 > web前端 > js教程 > 正文

中级:使用 React Router 进行路由

王林
发布: 2024-07-18 09:19:14
转载
1146人浏览过

中级:使用 react router 进行路由

路由是构建现代 web 应用程序的一个重要方面。 react router 是一个功能强大的库,使开发人员能够有效地处理 react 应用程序中的客户端路由。本指南将深入研究设置 react router 的基础知识、使用基本组件,并探索高级路由技术,例如嵌套路由、动态路由、路由参数和路由防护。

react 路由器简介

react router 允许您根据 url 管理不同组件的导航和渲染。它有助于构建具有无缝导航体验的单页应用程序 (spa)。

设置 react 路由器

要开始使用react router,请使用npm 或yarn 安装它。

npm install react-router-dom
登录后复制


yarn add react-router-dom
登录后复制

路由、交换机、链接和 navlink 组件

react router 提供了几个用于定义路由和处理导航的核心组件。

路线组件

route 组件用于定义路径并将其与组件关联。

示例:

import react from 'react';
import { browserrouter as router, route } from 'react-router-dom';
import home from './home';
import about from './about';

const app = () => {
  return (
    <router>
      <route path="/" exact component={home} />
      <route path="/about" component={about} />
    </router>
  );
};

export default app;
登录后复制

本例中,路径为 / 时渲染 home 组件,路径为 /about 时渲染 about 组件。

开关元件

switch 组件确保只渲染第一个匹配的路由。

示例:

import react from 'react';
import { browserrouter as router, route, switch } from 'react-router-dom';
import home from './home';
import about from './about';
import notfound from './notfound';

const app = () => {
  return (
    <router>
      <switch>
        <route path="/" exact component={home} />
        <route path="/about" component={about} />
        <route component={notfound} />
      </switch>
    </router>
  );
};

export default app;
登录后复制

在此示例中,如果没有匹配的路由,则渲染 notfound 组件。

链接组件

link 组件在您的应用程序中创建导航链接,类似于锚点(<a>)标签,但无需重新加载页面。

示例:

import react from 'react';
import { browserrouter as router, route, link } from 'react-router-dom';
import home from './home';
import about from './about';

const app = () => {
  return (
    <router>
      <nav>
        <link to="/">home</link>
        <link to="/about">about</link>
      </nav>
      <route path="/" exact component={home} />
      <route path="/about" component={about} />
    </router>
  );
};

export default app;
登录后复制

在此示例中,单击链接即可导航到相应的路线,而无需重新加载页面。

导航链接组件

navlink 组件与 link 组件类似,但提供了基于活动路线的附加样式功能。

示例:

import react from 'react';
import { browserrouter as router, route, navlink } from 'react-router-dom';
import home from './home';
import about from './about';

const app = () => {
  return (
    <router>
      <nav>
        <navlink exact to="/" activeclassname="active">
          home
        </navlink>
        <navlink to="/about" activeclassname="active">
          about
        </navlink>
      </nav>
      <route path="/" exact component={home} />
      <route path="/about" component={about} />
    </router>
  );
};

export default app;
登录后复制

在此示例中,activeclassname 属性将活动类应用于与当前路由匹配的链接。

先进的路由技术

嵌套路由

嵌套路线允许您在其他路线中创建路线,从而实现导航的分层结构。

行者AI
行者AI

行者AI绘图创作,唤醒新的灵感,创造更多可能

行者AI 100
查看详情 行者AI

示例:

import react from 'react';
import { browserrouter as router, route, switch, link, useroutematch } from 'react-router-dom';

const topic = ({ match }) => <h3>requested topic id: {match.params.topicid}</h3>;

const topics = () => {
  let { path, url } = useroutematch();
  return (
    <div>
      <h2>topics</h2>
      <ul>
        <li>
          <link to={`${url}/components`}>components</link>
        </li>
        <li>
          <link to={`${url}/props-v-state`}>props v. state</link>
        </li>
      </ul>
      <switch>
        <route exact path={path}>
          <h3>please select a topic.</h3>
        </route>
        <route path={`${path}/:topicid`} component={topic} />
      </switch>
    </div>
  );
};

const app = () => (
  <router>
    <div>
      <ul>
        <li>
          <link to="/">home</link>
        </li>
        <li>
          <link to="/topics">topics</link>
        </li>
      </ul>
      <switch>
        <route exact path="/">
          <h2>home</h2>
        </route>
        <route path="/topics" component={topics} />
      </switch>
    </div>
  </router>
);

export default app;
登录后复制

在此示例中,主题组件包含嵌套路由,允许主题部分内的子导航系统。

动态路由

动态路由允许您基于动态参数创建路由,例如用户 id 或产品 id。

示例:

import react from 'react';
import { browserrouter as router, route, switch, link } from 'react-router-dom';

const user = ({ match }) => <h3>user id: {match.params.userid}</h3>;

const app = () => (
  <router>
    <div>
      <ul>
        <li>
          <link to="/user/1">user 1</link>
        </li>
        <li>
          <link to="/user/2">user 2</link>
        </li>
      </ul>
      <switch>
        <route path="/user/:userid" component={user} />
      </switch>
    </div>
  </router>
);

export default app;
登录后复制

在此示例中,用户组件使用作为路由参数传递的用户 id 进行渲染。

路由参数

路由参数允许您从 url 捕获值并在组件中使用它们。

示例:

import react from 'react';
import { browserrouter as router, route, switch, link } from 'react-router-dom';

const product = ({ match }) => <h3>product id: {match.params.productid}</h3>;

const app = () => (
  <router>
    <div>
      <ul>
        <li>
          <link to="/product/101">product 101</link>
        </li>
        <li>
          <link to="/product/202">product 202</link>
        </li>
      </ul>
      <switch>
        <route path="/product/:productid" component={product} />
      </switch>
    </div>
  </router>
);

export default app;
登录后复制

在本例中,product组件使用productid路由参数来显示产品id。

路由守卫和重定向

路由防护和重定向可帮助您根据条件(例如用户身份验证)控制对某些路由的访问。

保护路线

为了保护路由,您可以创建一个高阶组件(hoc),在渲染组件之前检查条件(例如,用户身份验证)。

示例:

import react from 'react';
import { browserrouter as router, route, redirect } from 'react-router-dom';

const isauthenticated = false;

const privateroute = ({ component: component, ...rest }) => (
  <route
    {...rest}
    render={(props) =>
      isauthenticated ? <component {...props} /> : <redirect to="/login" />
    }
  />
);

const dashboard = () => <h3>dashboard</h3>;
const login = () => <h3>login</h3>;

const app = () => (
  <router>
    <div>
      <privateroute path="/dashboard" component={dashboard} />
      <route path="/login" component={login} />
    </div>
  </router>
);

export default app;
登录后复制

在此示例中,privateroute 组件在渲染 dashboard 组件之前检查用户是否经过身份验证。如果用户未通过身份验证,他们将被重定向到登录组件。

在 react router 中实现重定向

可以使用重定向组件来实现重定向,以编程方式将用户导航到不同的路线。

示例:

import React from 'react';
import { BrowserRouter as Router, Route, Redirect, Switch } from 'react-router-dom';

const OldPage = () => <h3>Old Page (will redirect)</h3>;
const NewPage = () => <h3>New Page</h3>;

const App = () => (
  <Router>
    <Switch>
      <Route path="/old-page">
        <Redirect to="/new-page" />
      </Route>
      <Route path="/new-page" component={NewPage} />
    </Switch>
  </Router>
);



export default App;
登录后复制

在此示例中,访问 /old-page 会自动将用户重定向到 /new-page。

结论

理解和使用 react router 实现路由对于构建健壮的 react 应用程序至关重要。通过掌握设置路由、使用 link 和 navlink 处理导航的基础知识,以及实现嵌套路由、动态路由、路由参数和路由防护等高级技术,您可以在应用程序中创建无缝且安全的导航体验。随着您继续发展您的技能,这些概念将成为您使用 react 构建复杂的单页应用程序的能力的基础。

以上就是中级:使用 React Router 进行路由的详细内容,更多请关注php中文网其它相关文章!

相关标签:
路由优化大师
路由优化大师

路由优化大师是一款及简单的路由器设置管理软件,其主要功能是一键设置优化路由、屏广告、防蹭网、路由器全面检测及高级设置等,有需要的小伙伴快来保存下载体验吧!

下载
来源:dev.to网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号