React Router常见面试题目

ops/2024/12/22 2:21:14/

1. React Router 支持哪几种模式?

React Router 支持以下两种主要模式:

  1. BrowserRouter (基于 HTML5 History API 的模式)

    • 原理
      • 利用 history.pushStatehistory.replaceState 操作浏览器历史栈,无需重新加载页面。
      • URL 看起来像传统 URL,如 /home
    • 优点
      • URL 结构简洁美观。
      • SEO 友好。
    • 缺点
      • 需要服务器配置支持,否则刷新页面时会导致 404。
  2. HashRouter (基于 URL 哈希的模式)

    • 原理
      • URL 中的 # 和其后内容不会被发送到服务器,浏览器通过 window.location.hash 检测路由变化。
      • 示例 URL:/index.html#/home
    • 优点
      • 不需要服务器配置,支持直接在本地文件系统中打开。
    • 缺点
      • URL 不够美观,不适合 SEO。

2. React Router 中的 Router 组件有几种类型?

常见的 Router 组件类型:

  1. BrowserRouter
    使用 HTML5 history 模式,提供更清晰的 URL。
  2. HashRouter
    使用哈希模式,适用于不需要服务器支持的项目。
  3. MemoryRouter
    存储在内存中的路由,不与浏览器地址栏同步,适用于测试环境。
  4. StaticRouter
    用于服务器端渲染 (SSR),路由配置是静态的。
  5. NativeRouter
    React Native 使用的路由组件。

3. 在 React Router 的 history 模式中,push 和 replace 方法有什么区别?

  • push 方法

    • 在浏览器历史记录栈中添加一个新条目。
    • 用户可以通过浏览器的后退按钮返回到之前的页面。
    • 示例:
      import { useHistory } from 'react-router-dom';
      const history = useHistory();
      history.push('/new-route');
      
  • replace 方法

    • 替换当前历史记录栈中的条目。
    • 不会新增历史记录,后退按钮无法返回到之前的页面。
    • 示例:
      import { useHistory } from 'react-router-dom';
      const history = useHistory();
      history.replace('/new-route');
      

4. React Router 中的 Switch 有什么作用?

  • 作用
    Switch 用于确保只有第一个匹配的路由会被渲染。
  • 原理
    遍历 Switch 内的子 Route,找到第一个 path 匹配的 Route 并渲染,忽略后续路由。
  • 示例
    import { Switch, Route } from 'react-router-dom';
    <Switch><Route path="/home" component={Home} /><Route path="/about" component={About} /><Route component={NotFound} /> {/* 兜底处理 */}
    </Switch>
    
  • 好处
    避免多个路由同时渲染,提高路由匹配效率。

5. React Router 支持的路由模式有哪些?

React Router 支持的模式:

  1. HTML5 history 模式(BrowserRouter)。
  2. 哈希模式(HashRouter)。
  3. 内存模式(MemoryRouter,通常用于测试或无浏览器环境)。

6. 什么是 React Router ? 常用的 Router 组件有哪些?

  • React Router 是一个路由库,用于在 React 应用中实现单页面应用(SPA)的路由功能。
  • 常用的 Router 组件
    1. BrowserRouter
    2. HashRouter
    3. MemoryRouter
    4. StaticRouter
    5. NativeRouter (React Native)

7. React Router 的路由是什么?它和普通路由有什么区别?有什么优缺点?

  • React Router 的路由

    • React Router 的路由是组件化的,通过 Route 组件定义路径和对应的组件。
    • 示例:
      import { BrowserRouter as Router, Route } from 'react-router-dom';
      <Router><Route path="/home" component={Home} />
      </Router>
      
  • 区别

    特性React Router 路由普通路由
    更新机制单页面应用,组件重新渲染整个页面重新加载
    URL 样式可定制 URL静态路径或文件映射
    用户体验快速切换,无刷新切换时刷新页面,速度较慢
  • 优点

    1. 用户体验好,页面切换快速。
    2. 易于动态加载组件,实现按需加载。
    3. 路由配置灵活,适合复杂应用。
  • 缺点

    1. SEO 支持需要额外配置(如 SSR)。
    2. URL 和组件的关联需要开发者手动维护。

8. 如何在 React 路由中实现动态加载模块,以实现按需加载?

可以使用 React 的 lazySuspense 组件来实现按需加载:

import React, { lazy, Suspense } from 'react';
import { BrowserRouter as Router, Route } from 'react-router-dom';const Home = lazy(() => import('./Home'));
const About = lazy(() => import('./About'));function App() {return (<Router><Suspense fallback={<div>Loading...</div>}><Route path="/home" component={Home} /><Route path="/about" component={About} /></Suspense></Router>);
}
  • 原理
    1. 当路由匹配时,组件才会动态加载。
    2. 提高初始页面加载速度,减少不必要的资源加载。

9. React Router 的路由变化时,如何重新渲染同一个组件?

当路由变化但仍在同一组件时,可以使用以下方法触发重新渲染:

  1. 使用 useEffect 监听路由参数变化
    import { useParams } from 'react-router-dom';
    import { useEffect } from 'react';function MyComponent() {const { id } = useParams();useEffect(() => {console.log(`Route parameter changed: ${id}`);}, [id]);return <div>Current ID: {id}</div>;
    }
    
  2. 强制更新组件
    如果路由参数未变化但需要强制刷新,可以使用 key 属性:
    import { useLocation } from 'react-router-dom';function MyComponent() {const location = useLocation();return <div key={location.pathname}>My Component</div>;
    }
    

以上是关于 React Router 的详细解答与示例,希望能帮助你更好地理解和应用它!

1. 如何在 React Router 中设置重定向?

在 React Router 中,可以通过以下两种方式实现重定向:

1.1 使用 <Navigate> 组件

在 React Router v6 中,使用 <Navigate> 组件来重定向:

import { Navigate } from 'react-router-dom';function App() {return (<Routes><Route path="/home" element={<Home />} /><Route path="/" element={<Navigate to="/home" />} /></Routes>);
}
1.2 使用 useNavigate Hook

通过 useNavigate 手动触发重定向:

import { useNavigate } from 'react-router-dom';function Login() {const navigate = useNavigate();const handleLogin = () => {// 登录逻辑navigate('/dashboard');};return <button onClick={handleLogin}>Login</button>;
}

2. 在 React Router 中如何获取 URL 参数?

2.1 使用 useParams Hook

useParams 是 React Router 提供的 Hook,用于获取动态路由参数:

import { useParams } from 'react-router-dom';function UserDetail() {const { userId } = useParams();return <div>User ID: {userId}</div>;
}
2.2 示例路由
<Routes><Route path="/user/:userId" element={<UserDetail />} />
</Routes>

访问 /user/123 会显示 User ID: 123


3. 如何配置 React Router 实现路由切换?

3.1 配置路由

使用 RoutesRoute 配置路由:

import { BrowserRouter as Router, Routes, Route } from 'react-router-dom';function App() {return (<Router><Routes><Route path="/" element={<Home />} /><Route path="/about" element={<About />} /></Routes></Router>);
}
3.2 路由切换

使用 <Link><NavLink> 组件触发切换:

import { Link } from 'react-router-dom';function Navbar() {return (<nav><Link to="/">Home</Link><Link to="/about">About</Link></nav>);
}

4. React Router 4 和 React Router 3 有哪些变化?新增了哪些特性?

4.1 主要变化
  • 组件化设计

    • React Router 4 使用完全组件化的设计,每个路由都是一个组件。
    • React Router 3 使用集中式配置方式。
  • 嵌套路由的实现

    • React Router 4:嵌套路由通过组件嵌套实现。
    • React Router 3:嵌套路由通过静态配置实现。
  • Switch 组件

    • React Router 4 引入了 <Switch>,用于匹配第一个符合条件的路由。
  • 动态路由加载

    • React Router 4 支持动态导入组件,优化加载性能。
4.2 示例对比

React Router 3 配置路由

import { Router, Route, browserHistory } from 'react-router';<Router history={browserHistory}><Route path="/" component={App}><Route path="about" component={About} /></Route>
</Router>;

React Router 4 配置路由

<BrowserRouter><Routes><Route path="/" element={<App />} /><Route path="/about" element={<About />} /></Routes>
</BrowserRouter>;

5. 在 React Router 中如何获取历史对象?

5.1 使用 useNavigate Hook

React Router v6 提供 useNavigate 代替 history

import { useNavigate } from 'react-router-dom';function Component() {const navigate = useNavigate();const goBack = () => navigate(-1);return <button onClick={goBack}>Go Back</button>;
}
5.2 v5 及更早版本的 history

早期版本使用 useHistory 获取 history 对象:

import { useHistory } from 'react-router-dom';function Component() {const history = useHistory();history.push('/home');
}

6. React Router 的实现原理是什么?

React Router 的核心是监听 URL 变化,并根据匹配规则动态渲染对应的组件。

6.1 核心原理
  • 路由监听
    通过 window.historywindow.location.hash 监听 URL 的变化。
  • 匹配规则
    使用 path-to-regexp 库将路径转换为正则表达式,匹配当前 URL。
  • 渲染更新
    匹配的路由组件通过 React 的状态更新机制触发重新渲染。
6.2 关键步骤
  1. 路由定义时,存储路径与组件的映射关系。
  2. URL 变化时,根据路径规则找到对应组件。
  3. 使用 React 渲染匹配的组件。

7. React 路由切换时,如果同一组件无法重新渲染,有哪些方法可以解决?

7.1 监听参数变化

使用 useEffectcomponentDidUpdate 监听参数变化:

import { useParams } from 'react-router-dom';function Component() {const { id } = useParams();useEffect(() => {console.log(`Route parameter changed: ${id}`);}, [id]);return <div>Current ID: {id}</div>;
}
7.2 强制重新渲染

通过更改组件的 key 强制重新渲染:

import { useLocation } from 'react-router-dom';function Component() {const location = useLocation();return <div key={location.pathname}>My Component</div>;
}
7.3 手动清理状态

在参数变化时清理状态,触发组件重新渲染:

useEffect(() => {setState(null); // 清理状态
}, [id]);

8. React Router 中的 Link 标签和 HTML 的 a 标签有什么区别?

8.1 区别
特性<Link><a>
页面刷新不刷新页面刷新页面
性能单页面跳转,速度更快每次跳转都重新加载资源
路由支持集成 React Router 路由不支持
SEO 支持同样支持支持
8.2 示例对比

使用 <a> 标签

<a href="/about">About</a>

每次点击都会刷新页面。

使用 <Link> 标签

import { Link } from 'react-router-dom';<Link to="/about">About</Link>

点击不会刷新页面,仅更新路由。


以上是关于 React Router 各个问题的详细解答及代码示例,希望能够帮助你深入理解和应用 React Router!


http://www.ppmy.cn/ops/143911.html

相关文章

移动网络(2,3,4,5G)设备TCP通讯调试方法

背景&#xff1a; 当设备是移动网络设备连接云平台的时候&#xff0c;如果服务器没有收到网络数据&#xff0c;移动物联设备发送不知道有没有有丢失数据的时候&#xff0c;需要一个抓取设备出来的数据和服务器下发的数据的方法。 1.服务器系统是很成熟的&#xff0c;一般是linu…

DNS 服务器是什么?有什么作用

一、DNS 服务器的定义 DNS 服务器即域名系统&#xff08;Domain Name System&#xff09;服务器。它是一种在互联网基础设施中扮演关键角色的服务器。在互联网的世界里&#xff0c;每台设备&#xff08;如服务器、计算机等&#xff09;都有一个唯一的 IP 地址&#xff0c;就像…

git企业开发的相关理论(二)

目录 git企业开发的相关理论&#xff08;一&#xff09; 八.修改文件 九.版本回退 十.撤销修改 情况一(还没有add) 情况二(add后还没有commit) 情况三(commit后还没有push) 十一.删除本地仓库中的文件 方法一 方法二 十二.理解分支 1.常见的分支工作流程 2.合并冲…

【优选算法---分治】快速排序三路划分(颜色分类、快速排序、数组第K大的元素、数组中最小的K个元素)

一、颜色分类 题目链接: 75. 颜色分类 - 力扣&#xff08;LeetCode&#xff09; 题目介绍&#xff1a; 给定一个包含红色、白色和蓝色、共 n 个元素的数组 nums &#xff0c;原地 对它们进行排序&#xff0c;使得相同颜色的元素相邻&#xff0c;并按照红色、白色、蓝色顺序…

MySQL 8.0与PostgreSQL 15.8的性能对比

以下是MySQL 8.0与PostgreSQL 15.8的性能对比&#xff1a; MySQL 8.0性能特点&#xff1a; MySQL在处理大量读操作时表现出色&#xff0c;其存储引擎InnoDB提供了行级锁定和高效的事务处理&#xff0c;适用于并发读取的场景。MySQL通过查询缓存来提高读取性能&#xff0c;查询缓…

子域提取工具,子域名收集神器,支持多种数据源和枚举选项,域名发现工具,可以为任何目标枚举海量的有效子域名,安全侦察工具,利用证书透明原则监控部署的新子域

子域提取工具&#xff0c;子域名收集神器&#xff0c;支持多种数据源和枚举选项&#xff0c;域名发现工具&#xff0c;可以为任何目标枚举海量的有效子域名&#xff0c;安全侦察工具&#xff0c;利用证书透明原则监控部署的新子域。 需要对目标域名的子域进行深入分析&#xff…

C语言中,假如我一个C文件包含了两个头文件,而两个头文件中都有对同一个宏或结构体的定义,编译时如何处理?

两个头文件中都有对同一个宏的定义的情况 在C语言中&#xff0c;如果两个头文件中都定义了同一个宏&#xff0c;并且你在C文件中包含了这两个头文件&#xff0c;会发生宏重新定义的问题。编译器的处理方式取决于宏的具体定义内容&#xff1a; 1. 如果两个宏定义完全相同&…

第十四届蓝桥杯Scratch国赛真题—转动的车轮

转动的车轮 编程实现&#xff1a; 转动的车轮&#xff08;车轮使用画笔绘制&#xff0c;画面中不能出现其他角色&#xff0c;否则0分&#xff09;。 注&#xff1a;角色、背景非源素材。 具体要求&#xff1a; 1). 点击绿旗&#xff0c;背景如图所示&#xff1b; 2). 等待1…