React返回上一个页面,会重新挂载吗

news/2024/10/4 7:06:19/

在 React 中,当你使用 React Router 或其他导航方法返回到上一个页面时,默认情况下,返回的页面会重新挂载。也就是说,组件会重新执行它的生命周期方法(或钩子函数),例如 useEffect、useState 的初始状态设定等。

1、默认情况下组件会重新挂载

使用 useNavigate 或者浏览器的返回按钮时,返回到之前的页面会触发该页面组件的重新挂载。通常来说,页面会重新加载,并且该组件的 useEffect(如果设置了依赖项为 [])会再次执行。

import React, { useEffect } from 'react';const PreviousPage = () => {useEffect(() => {console.log('Component mounted');}, []);return <div>Previous Page</div>;
};

当你从这个页面导航到其他页面再返回时,console.log(‘Component mounted’) 会再次打印,因为组件重新挂载了。

2、如何避免组件重新挂载

如果你想避免组件重新挂载(比如保持表单数据、滚动位置等),可以通过以下几种方法来实现页面的缓存或状态的持久化。

import { Outlet } from 'react-router-dom';const Layout = () => {return (<div><header>Header</header><Outlet /> {/* 这里放置的子组件会根据路由切换,而 Layout 不会重新挂载 */}</div>);
};

2.1、使用 React Router 的 或嵌套路由

在 React Router v6 中,如果你将组件放在 Layout 组件或使用嵌套路由时,返回页面时可以避免某些组件的重新挂载(通常是保持页面布局组件)。

import { Outlet } from 'react-router-dom';const Layout = () => {return (<div><header>Header</header><Outlet /> {/* 这里放置的子组件会根据路由切换,而 Layout 不会重新挂载 */}</div>);
};

这样,Layout 组件在页面切换时不会重新挂载,只会替换 Outlet 中的内容,允许你保持一些全局布局或共享状态。

2.2、缓存页面状态

使用状态管理工具(如 Redux、Context API),或者将状态保存在 localStorage 或 sessionStorage 中,可以在返回页面时恢复状态。

import React, { useState, useEffect } from 'react';const FormPage = () => {const [inputValue, setInputValue] = useState(() => {// 从 localStorage 恢复初始值return localStorage.getItem('formInput') || '';});// 当 inputValue 改变时,保存到 localStorageuseEffect(() => {localStorage.setItem('formInput', inputValue);}, [inputValue]);return (<div><inputtype="text"value={inputValue}onChange={(e) => setInputValue(e.target.value)}/></div>);
};export default FormPage;

2.3、 使用 React 的 useMemo 或 useRef

如果组件中的某些部分需要在重新挂载时保持不变,可以使用 useMemo 或 useRef 来缓存那些不需要每次重新计算的数据。

  • useMemo:用来记住计算结果,直到依赖项发生变化。
  • useRef:用于存储跨渲染周期保持不变的值。
const ExpensiveComponent = () => {const memoizedValue = useMemo(() => {return performExpensiveCalculation();}, []);return <div>{memoizedValue}</div>;
};

2.4、使用 React Query 等工具缓存数据

React Query 等库可以帮助你缓存请求数据。当你返回到一个页面时,它不会重新发起网络请求,而是使用缓存的数据来重新渲染页面。

3、 React Router 提供的 useLocation 的状态传递

如果你使用 React Router 的 navigate 时传递状态,你可以在返回页面时通过 useLocation 恢复状态,而不是让组件重新计算或重新挂载。

import { useNavigate, useLocation } from 'react-router-dom';const PageComponent = () => {const location = useLocation();const navigate = useNavigate();useEffect(() => {if (location.state) {console.log('Restored state:', location.state);}}, [location.state]);return <div>Some content</div>;
};

4、使用 React Router 的 keep-alive 插件

React Router 没有内置的“缓存页面”功能,但你可以使用第三方插件,比如 react-activation,实现页面的“保活”功能,即保持页面状态不变而不重新挂载。

5、总结

  • 1、默认情况下,返回到之前的页面会重新挂载组件,即重新执行组件的生命周期或钩子函数。
  • 2、避免组件重新挂载的方法:
    使用 React Router 的嵌套路由或布局组件。
    通过 localStorage 或 sessionStorage 缓存状态。
    使用 useMemo、useRef 缓存部分计算结果。
    使用 React Query 等工具缓存数据。
    使用 react-activation 等插件保持页面不重新挂载。

http://www.ppmy.cn/news/1534281.html

相关文章

PHP反序列化8(phar反序列化)

考点8&#xff1a;phar反序列化 <aside> &#x1f4a1; 使用条件 </aside> 文件上传时&#xff0c;不必要.phar后缀&#xff0c;文件上传不是难点&#xff01;&#xff01;&#xff01;&#xff08;phar伪协议自动解析成.phar文件&#xff09; phar文件本质上是…

【深度学习基础模型】液态状态机(Liquid State Machines, LSM)详细理解并附实现代码。

【深度学习基础模型】液态状态机&#xff08;Liquid State Machines, LSM&#xff09;详细理解并附实现代码。 【深度学习基础模型】液态状态机&#xff08;Liquid State Machines, LSM&#xff09;详细理解并附实现代码。 文章目录 【深度学习基础模型】液态状态机&#xff0…

Tiny Transformer:从零开始构建简化版Transformer模型

引言 自然语言处理&#xff08;NLP&#xff09;与计算机视觉&#xff08;CV&#xff09;有显著差异&#xff0c;各自任务的独特性决定了它们适用的模型架构。在CV中&#xff0c;卷积神经网络&#xff08;CNN&#xff09;长期占据主导地位&#xff0c;而在NLP领域&#xff0c;循…

Nagle 算法:优化 TCP 网络中小数据包的传输

1. 前言 在网络通信中&#xff0c;TCP&#xff08;传输控制协议&#xff09;是最常用的协议之一&#xff0c;广泛应用于各种网络应用&#xff0c;如网页浏览、文件传输和在线游戏等。然而&#xff0c;随着互联网的普及&#xff0c;小数据包的频繁传输成为一个不容忽视的问题。…

mac配置python出现DataDirError: Valid PROJ data directory not found错误的解决

最近在利用python下载SWOT数据时出现以下的问题&#xff1a; import xarray as xr import s3fs import cartopy.crs as ccrs from matplotlib import pyplot as plt import earthaccess from earthaccess import Auth, DataCollections, DataGranules, Store import os os.env…

C++学习,信号处理

C信号处理&#xff0c;依赖于操作系统提供的API。信号处理主要用于响应外部事件&#xff0c;如中断信号&#xff08;如SIGINT, SIGTERM等&#xff09;&#xff0c;这些信号可以由操作系统、其他程序或用户生成。 在Unix-like系统&#xff08;如Linux和macOS&#xff09;中&…

three.js 通过着色器实现热力图效果

three.js 通过着色器实现热力图效果 在线预览 https://threehub.cn/#/codeMirror?navigationThreeJS&classifyshader&idheatmapShader 在 https://threehub.cn 中还有很多案例 <!doctype html> <html lang"en"> <head> <meta charse…

RabbitMQ 界面管理说明

1.RabbitMQ界面访问端口和后端代码连接端口不一样 界面端口是15672 http://localhost:15672/ 后端端口是 5672 默认账户密码登录 guest 2.总览图 3.RabbitMq数据存储位置 4.队列 4.客户端消费者连接状态 5.队列运行状态 6.整体运行状态