如何滚动到特定位置?scrollIntoView了解一下

前言

平常开发中,我们会遇到某些场景,比如说我浏览的页面滚动到了的某个特定位置,下一次浏览还需要保留在原来位置。

通常我们缓存当前浏览滚动的高度,那么跳转到特定的位置我们介绍几种常用的方式。

1. 常用跳转方式

假设我们有一个具有 id 为 "container" 的容器元素,滚动到100px处:

1.1 使用 scrollTop属性

具体代码:

javascript 复制代码
var container = document.getElementById("container");
container.scrollTop = 100;

1.2 使用 scrollBy 方法:

该方法接受两个参数,分别表示水平和垂直滚动的像素数。

具体代码:

javascript 复制代码
var container = document.getElementById("container");
container.scrollBy(0, 100);

1.3 使用 scrollTo 方法

类似于 scrollBy 方法,scrollTo 方法可以用于滚动元素到指定的位置。不同之处在于,scrollTo 方法接受绝对的滚动位置而不是相对位置。

具体代码:

javascript 复制代码
var container = document.getElementById("container");
container.scrollTo(0, 500);

1.4 使用id锚点链接跳转

具体代码:

js 复制代码
<a href="#target-id">跳转到目标</a>

<div id="target-id">
  <!-- 目标内容 -->
</div>

缺点是:需要唯一的id,且url地址栏有hash,会导致路由框架跳转错误。

2. scrollIntoView

介绍一个非常好用的前端API---scrollintoView,可以方便地让页面元素滚动到可视区域。

2.1 属性介绍

  • behavior 定义滚动是立即的还是平滑的动画。

    • smooth:滚动应该是平滑的动画。
    • instant:滚动应该通过一次跳跃立刻发生。
    • auto:滚动行为由 scroll-behavior 的计算值决定。
  • block 定义垂直方向的对齐,默认为 start

    • start
    • center
    • end
    • nearest
  • inline 定义水平方向的对齐,默认为 nearest

    • start
    • center
    • end
    • nearest

2.2 案例

例如:获取到某个元素的dom节点,以任意页面为例,通过当前元素的$0进行调用

单纯调用: 添加属性调用,比如blockcenter,则居中显示:

2.3 应用场景

它可以应用于各种不同的场景,例如以下几个:

  1. 导航菜单:当用户点击导航菜单中的链接时,可以使用 scrollIntoView 将页面滚动到相应的部分。

  2. 页面内锚点链接:当页面内存在锚点链接时,可以使用 scrollIntoView 将页面滚动到对应的位置。

  3. 滚动加载:在一些需要滚动加载内容的情况下,当用户滚动到页面底部时,可以使用 scrollIntoView 将新加载的内容滚动到视图中。

  4. 表单验证:当用户提交表单时,如果发现输入错误,可以使用 scrollIntoView 将错误的输入字段滚动到可视区域内,以便用户直接看到并修改错误。

4. 总结

本文介绍了常用滚动到特定位置的一些方法属性。 主要说明如何使用scrolllntoView API来将页面元素滚动到可视范围内,详细说明该API的使用方法和配置选项以及应用场景。

注意:该方法不仅适用于整个网页的滚动,也可以用于任何一个区域的滚动。

单纯记录,不喜勿喷。如果错误,请指正O^O!

相关推荐
sbjdhjd7 小时前
Redis 主从复制、哨兵高可用与 Cluster 集群部署实验手册
运维·前端·redis·云原生·开源·bootstrap·html
乐兮创想 小林7 小时前
企业官网移动端性能优化实战:从 Core Web Vitals 到图片/CDN/响应式的工程清单
前端·性能优化·网站建设·北京网站建设公司
前端一小卒8 小时前
不手写代码的第 30 天,我才明白前端这个岗位还剩什么
前端·javascript·ai编程
Ajie'Blog8 小时前
Copilot Agent Tasks API 开放:AI 编程开始进入后台任务时代
服务器·前端·javascript·人工智能·copilot·ai编程
老毛肚8 小时前
jeecgboot vue TS & 模板化 04
前端·javascript·vue.js
AI_零食10 小时前
鸿蒙PC Electron跨平台应用开发:24时区时间表应用详解
前端·华为·electron·开源·harmonyos·鸿蒙
Electrolux10 小时前
[onlyoffice-v9]纯前端怎么实现编辑预览office
前端·javascript·github
码云之上10 小时前
聊聊如何设计一个高效、稳定的 Node.js 接入层
前端·后端·node.js
kyriewen11 小时前
我读了一遍 Babel 编译后的 async/await,终于搞懂了它的原理(附 20 行手写实现)
前端·javascript·面试
IT_陈寒11 小时前
Vite项目build后路由404了?你可能漏了这个小配置
前端·人工智能·后端