【前端实战】如何让用户回到上次阅读的位置?

在阅读类、资讯类、博客、文档、论坛、长文章详情页等场景中,让用户下次打开(或返回)时自动滚回到上次阅读位置,是提升用户体验的经典需求。

2025–2026 年主流实现方案已经非常成熟,以下按实用性 + 稳定性 + 性能从高到低排序,附带代码示例和优缺点对比

方案对比表(2026 年推荐优先级)

优先级方案适用场景优点缺点 / 注意事项推荐指数
★★★★★URL Hash + 章节/段落锚点 + localStorage长文章、文档、章节化内容分享友好、SEO 友好、内容变动不漂移需要提前给关键节点加 id最高
★★★★☆IntersectionObserver + 探针元素无限滚动 / 懒加载长列表精准记录“已读到哪个区块”、内容动态变化鲁棒代码稍复杂、需插入探针元素非常推荐
★★★★scrollY + localStorage + 节流/防抖普通静态长页实现最简单、兼容性极好内容增删/高度变化会导致位置漂移基础首选
★★★Vue/React Router scrollBehaviorSPA 单页应用(列表 → 详情 → 返回)框架原生支持、优雅只适合路由切换,不适合刷新/关闭浏览器后恢复SPA 必备
★★☆sessionStorage 或 memory cache只在本会话内记住更轻量、不污染 localStorage关闭浏览器/标签就丢失辅助

1. 最推荐:URL Hash + 章节锚点 + localStorage 双保险(鲁棒性最高)

思路:

  • 给文章重要章节/段落加 id(h2/h3/p 等)
  • 滚动时实时(节流)更新 URL hash 为当前最靠近视口的章节 id
  • 同时把当前章节 id 存 localStorage(防用户直接刷新没 hash)
  • 进入页面时:优先读 hash → 次选 localStorage → 最后默认顶部
<!-- 文章结构示例 --><articleid="article-detail"><h2id="section-1">第一章:引言</h2><p>...</p><h2id="section-2">第二章:原理</h2><!-- ... 更多章节 --></article>
// 1. 工具函数:找当前最接近视口顶部的 heading 元素functiongetCurrentSection(){const headings = document.querySelectorAll('h2,h3');// 或其他章节标志let current =null;let minDistance =Infinity; headings.forEach(h=>{const rect = h.getBoundingClientRect();const distance = Math.abs(rect.top);// 距离视口顶部if(distance < minDistance){ minDistance = distance; current = h;}});return current?.id;}// 2. 节流更新 hash & storagelet ticking =false; window.addEventListener('scroll',()=>{if(!ticking){requestAnimationFrame(()=>{const sectionId =getCurrentSection();if(sectionId){// 更新 URL hash(不刷新页面) history.replaceState(null,'',`#${sectionId}`);// 同时存 localStorage(key 建议带文章唯一 id) localStorage.setItem(`read-pos-${location.pathname}`, sectionId);} ticking =false;}); ticking =true;}},{passive:true});// 3. 页面加载时恢复 window.addEventListener('load',()=>{let targetId = location.hash.slice(1);// 优先 hashif(!targetId){ targetId = localStorage.getItem(`read-pos-${location.pathname}`);}if(targetId){const el = document.getElementById(targetId);if(el){// 可加一点偏移,避免正好卡在顶部看不见标题 el.scrollIntoView({behavior:'smooth',block:'start'});// 或 window.scrollTo(0, el.offsetTop - 80);}}});

优点:内容布局变化也不容易漂移,用户可直接分享带 # 的链接。

2. IntersectionObserver + 探针元素(适合动态/无限加载内容)

思路:在文章中每隔 N 段插入一个透明的“探针”div(高度很小),用 IO 观察哪个探针进入视口,就记录它的 data-id。

<p>段落内容...</p><divclass="probe"data-id="para-15"></div><p>下一段...</p>
const probes = document.querySelectorAll('.probe');const observer =newIntersectionObserver(entries=>{ entries.forEach(entry=>{if(entry.isIntersecting){const id = entry.target.dataset.id; localStorage.setItem(`read-pos-${location.pathname}`, id);// 可选:更新 URL hash 如 #para-15}});},{threshold:0.8});// 进入 80% 就算“读到” probes.forEach(p=> observer.observe(p));// 恢复时const savedId = localStorage.getItem(`read-pos-${location.pathname}`);if(savedId){ document.querySelector(`[data-id="${savedId}"]`)?.scrollIntoView({behavior:'smooth',block:'start'});}

优点:对懒加载、虚拟列表友好,内容增删不影响已记录的区块。

3. 最简单方案:scrollY + localStorage(适合静态页)

// 保存(节流 200ms)let saveTimer; window.addEventListener('scroll',()=>{clearTimeout(saveTimer); saveTimer =setTimeout(()=>{ localStorage.setItem(`scroll-${location.pathname}`, window.scrollY);},200);});// 恢复 window.addEventListener('load',()=>{const saved = localStorage.getItem(`scroll-${location.pathname}`);if(saved){ window.scrollTo(0,parseInt(saved));}});

注意:内容高度变化会导致漂移 → 所以优先用上面两种。

4. Vue/React Router 项目额外福利

// Vue Routerconst router =createRouter({scrollBehavior(to, from, savedPosition){if(savedPosition)return savedPosition;// 浏览器前进/后退return{top:0};// 新页面默认顶部// 或结合 localStorage 自定义恢复}});// React Router v6import{ useEffect }from'react';import{ useLocation }from'react-router-dom';functionScrollToTop(){const{ pathname }=useLocation();useEffect(()=>{const saved = localStorage.getItem(`scroll-${pathname}`); window.scrollTo(0, saved ?parseInt(saved):0);},[pathname]);// ... 同时监听 scroll 保存}

总结:2026 年推荐组合拳

  1. 静态/半静态长文 → URL Hash + localStorage 双存(首选)
  2. 无限滚动/动态内容 → IntersectionObserver 探针
  3. SPA 路由切换 → 框架 scrollBehavior + storage 兜底
  4. key 设计:用 location.pathname 或文章唯一 ID(如 /post/123read-pos-/post/123
  5. 清理:可加过期时间(如 7 天后自动删),避免 localStorage 塞满

你现在是做资讯详情页小说阅读文档站还是论坛帖子?告诉我具体场景,我可以给你最贴合的完整代码(Vue/React/纯js 都行)。

Read more

IROS 2025 无人机及集群 学习与控制合集

IROS 2025 无人机及集群 学习与控制合集

无人机系统面临着复杂多变的环境挑战,如动态障碍物、风扰、系统故障等,传统的基于精确模型的控制方法往往难以适应这些不确定性。为此,学习与控制相结合的智能方法成为研究热点。 刚刚过去的IROS 2025上,涌现了多篇聚焦单体无人机和多智能体的结合学习与控制的论文,体现了其在提升系统自主性与适应性方面的探索。NOKOV度量动作捕捉系统为研究提供高精度位姿“真值”,助力现实实验验证。同时在多智能体研究中支持控制算法的闭环执行。 · 单体无人机 一、基于学习的动态模型——在状态空间层面进行学习,获得系统的动力学模型 论文:PI-WAN: A Physics-Informed Wind-Adaptive Network for Quadrotor Dynamics Prediction in Unknown Environments (IROS 2025) 作者:Mengyun Wang, Bo Wang, Yifeng Niu and Chang Wang 国防科技大学 牛轶峰老师团队针对四旋翼在未知风扰环境中建模不准、数据驱动方法泛化差的问题,提出物理信息风自适应网络,将物理

宇树科技机器人核心技术

宇树科技机器人核心技术

前言 宇树科技作为全球足式/人形机器人领域的标杆企业,其技术体系覆盖消费级(Go2)、工业级(B2)、人形(G1/H1)全产品线,以“硬件自研+软件全栈+AI赋能”构建核心壁垒。本文不仅拆解宇树机器人的关键技术(单硬件、单软件、软硬件协同、AI+),还配套就业技能图谱、学习路线与工具推荐,适合机械、电子、计算机、AI领域开发者/求职者参考。 一、宇树科技机器人核心技术全景(附插图建议) 宇树的技术体系可概括为“四层金字塔结构”,从下到上实现“能运动→会运动→智能运动”的进阶: 技术层级核心定位代表技术应用价值底层硬件机器人“躯体骨架”自研伺服电机、分层计算平台、4D激光雷达保障运动性能与环境适配性全栈软件机器人“智慧大脑”MPC/WBC控制算法、SLAM感知融合、ROS2中间件实现精准控制与灵活交互软硬件协同机器人“神经中枢”实时控制闭环、

(6-4-02)IMU融合与机体状态估计:综合实战:腿式机器人的IMU关节融合与状态估计(2)

(6-4-02)IMU融合与机体状态估计:综合实战:腿式机器人的IMU关节融合与状态估计(2)

6.4.3  状态估计 “src”目录包含本项目状态估计的核心算法实现和工具模块,涵盖惯性导航与人形机器人运动状态估计的完整流程,包括EKF状态预测与更新、IMU数据补偿与积分、机器人足端运动学计算、静态初始对准、导航结果与误差输出、数据流生成及可视化工具,整体提供从原始传感器数据到导航状态估计和分析的全链路功能,实现机器人高精度运动导航和状态监控。 1. IMU数据的传播与补偿 文件src/imuPropagation.py的功能是提供IMU数据的传播与补偿机制,用于惯性导航系统(INS)中状态更新。INSMech 类实现了基于前一时刻和当前IMU测量的速度、位置和姿态传播,同时对IMU角速度和加速度进行偏差与缩放误差补偿。_wrap_yaw_inplace用于将偏航角限制在 -π,π 范围内。 import numpy as np from scipy.spatial.transform import Rotation as R def _wrap_yaw_inplace(euler_

Stable Diffusion 秋叶大神2025最新整合一键安装包

Stable Diffusion 秋叶大神2025最新整合一键安装包

这段时间我在折腾 Stable Diffusion,期间试过很多安装方式。有手动安装的,也有别人做好的整合包。手动安装的方式对环境要求高,步骤也多,系统要装 Python,要装依赖,还要配好运行库,哪一步出错都要重新查资料,挺消耗时间。后来了解到秋叶大神做的整合一键安装包,这个版本省掉了很多折腾,对新手比较友好。 我自己把安装流程整理了一遍,又结合网上的信息,把一些需要注意的地方写下来,希望能帮到想尝试 Stable Diffusion 的人。 这里完整下载链接 秋叶整合包是什么 这个整合包属于别人已经帮你配好的版本,里面把 Stable Diffusion WebUI、模型管理、插件、运行环境都准备好了。下载之后按照提示解压,点一下启动脚本就能跑起来,不需要另外去折腾环境。 整合包里放的 WebUI 是常见的 AUTOMATIC1111 版本,所以大部分教程都能直接用。适合想直接出图、想先体验一下模型效果的人。 系统环境方面 我现在用的是 Windows 电脑,所以下面写的内容主要基于