滚动元素到可视区

概述

在项目里面,肯定会遇到元素跳转到可视区的需求,比较常见的就像百度搜索的时候,根据目录节点跳转指定章节到可视区,如下:

实现方案

地址哈希

点击对应元素,直接会在地址栏上拼接上元素hash值

js 复制代码
//a标签herf绑定hash id
<a href="#section-id">跳转到章节</a>
//绑定锚点hash id
<div id="section-id">目标内容</div>

好处

  • 直接地址分享给别人,能直接定位到指定元素为止

缺点

  • 无法实现更加精准的定位,只能默认顶部对齐(如:底部对齐、中间对齐、自定义位置对齐)
  • 如果spa应用使用hash路由,可能会出现些冲突,需要额外处理

js跳转

可通过如下api方式操作,更加灵活

1. scrollIntoView()

javascript 复制代码
element.scrollIntoView({
  behavior: 'smooth', // 可选: 'auto' 或 'smooth'
  block: 'nearest',   // 可选: 'start', 'center', 'end', 'nearest'
  inline: 'nearest'   // 可选: 'start', 'center', 'end', 'nearest'
});

2. scrollTo() 或 scroll()

javascript 复制代码
// 滚动到特定位置
window.scrollTo({
  top: element.offsetTop,
  behavior: 'smooth'
});

// 或者使用元素滚动
container.scroll({
  top: element.offsetTop - container.offsetTop,
  behavior: 'smooth'
});

好处

  • 自定义程度更好,可根据自己实际需求进行处理

缺点

  • 对外分享需要额外处理定位(如通过路由参数)
相关推荐
超人气王10 小时前
新手学前端JS浅拷贝和深拷贝:对象复制竟然是个“替身文学”?
javascript·面试
YHL10 小时前
📚 JS执行机制(执行上下文 + 调用栈 + 编译流程)
前端·javascript
不简说10 小时前
这次真香!sv-print 可视化打印设计器更新:插件脚手架、Excel 导出、弹窗 API 三连发
前端·javascript·前端框架
无聊的老谢11 小时前
Web GIS 最佳实践:Vue 集成 Leaflet/OpenLayers 实现基站海量点位渲染
前端·javascript·vue.js
yingyima11 小时前
GCP Cloud Scheduler 核心语法与实战示例速查手册
前端
用户573501072520611 小时前
Elpis 项目阶段性总结 - 基于 vue3 完成领域模型架构建设
前端
东风破_11 小时前
V8 如何执行你的代码——编译、上下文与调用栈
javascript
假如让我当三天老蒯11 小时前
为什么 setData 能获取到 prev 参数?(自学用)
前端·react.js
AskHarries11 小时前
Workspace:文件系统、项目上下文和执行边界
java·服务器·前端
Aphasia31111 小时前
从内存模型看深浅拷贝
前端·javascript·面试