首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[第19期] 介绍一个页面平滑滚动小技巧

[第19期] 介绍一个页面平滑滚动小技巧

作者头像
皮小蛋
发布2020-02-29 16:57:13
1.3K0
发布2020-02-29 16:57:13
举报
文章被收录于专栏:前端皮小蛋前端皮小蛋

背景

今天写需求的时候发现一个小的优化点:用户选择了一些数据之后, 选择的条目需要高亮, 有时候列表很长, 为了提升用户体验,需要加个滚动, 自动滚动到目标位置。

下午简单的查了一下, 问题顺利解决, 就把这个小技巧分享一下给大家。

正文

有几种不同的方式来解决这个小问题。

1.scrollTop

第一想到的还是 scrollTop, 获取元素的位置, 然后直接设置:

// 设置滚动的距离element.scrollTop = value;

不过这样子有点生硬, 可以加个缓动效果:

var scrollSmoothTo = function (position) {    if (!window.requestAnimationFrame) {        window.requestAnimationFrame = function (callback, element) {            return setTimeout(callback, 17);        };    }    // 当前滚动高度    var scrollTop = document.documentElement.scrollTop || document.body.scrollTop;    // 滚动step方法    var step = function () {        // 距离目标滚动距离        var distance = position - scrollTop;        // 目标滚动位置        scrollTop = scrollTop + distance / 5;        if (Math.abs(distance) < 1) {            window.scrollTo(0, position);        } else {            window.scrollTo(0, scrollTop);            requestAnimationFrame(step);        }    };    step();};
// 平滑滚动到顶部,可以直接:
scrollSmoothTo(0)

jQuery 中的 animate 方法也可以实现类似的效果:

$('xxx').animate({ scrollTop: 0;});

2. scroll-behavior

把 scroll-behavior:smooth; 写在滚动容器元素上,也可以让容器(非鼠标手势触发)的滚动变得平滑。

.list { scroll-behavior: smooth;}

在PC上, 网页默认滚动是在 html 标签上的,移动端大多数在 body 标签上, 那么这行定义到全局的css中就是:

html, body { scroll-behavior: smooth;}

3. scrollIntoView

Element.scrollIntoView() 方法, 让当前的元素滚动到浏览器窗口的可视区域内。

语法:

var element = document.getElementById("box");element.scrollIntoView(); // 等同于element.scrollIntoView(true) element.scrollIntoView(alignToTop); // Boolean型参数 element.scrollIntoView(scrollIntoViewOptions); // Object型参数

scrollIntoView 方法接受两种形式的值:

1. 布尔值

* 如果为true,元素的顶端将和其所在滚动区的可视区域的顶端对齐。

* 相应的 scrollIntoViewOptions: {block: "start", inline: "nearest"}。

这是这个参数的默认值。

* 如果为 false,元素的底端将和其所在滚动区的可视区域的底端对齐。

* 相应的scrollIntoViewOptions: { block: "end", inline: "nearest" }。

2. Options 可选对象

{    behavior: "auto" | "instant" | "smooth", 默认为 "auto"。    block: "start" | "end", 默认为 "start"。    inline: "start" | "center" | "end", | "nearest"。默认为 "nearest"。}

1. behavior表示滚动方式。auto 表示使用当前元素的 scroll-behavior 样式。instant`和`smooth表示`直接滚到底`和`使用平滑滚动`。

2. block表示块级元素排列方向要滚动到的位置。对于默认的writing-mode: horizontal-tb;来说,就是竖直方向。start表示将视口的顶部和元素顶部对齐;center表示将视口的中间和元素的中间对齐;end表示将视口的底部和元素底部对齐;`nearest`表示就近对齐。

3. inline表示行内元素排列方向要滚动到的位置。对于默认的`writing-mode: horizontal-tb`来说,就是水平方向。其值与`block`类似。

4. scrollIntoView 浏览器兼容性

最后我用的是 scrollIntoView, 问题完美解决。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-10-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端皮小蛋 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档