分享一个页面平滑滚动小技巧(推荐)


Posted in HTML / CSS onOctober 23, 2019

背景

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

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

正文

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

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 方法接受两种形式的值:

布尔值

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

  • 相应的 scrollIntoViewOptions: {block: "start", inline: "nearest"}。这是这个参数的默认值。

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

  • 相应的scrollIntoViewOptions: { block: "end", inline: "nearest" }Options 对象
{
    behavior: "auto" | "instant" | "smooth", 默认为 "auto"。
    block: "start" | "end", 默认为 "start"。
    inline: "start"| "center"| "end", | "nearest"。默认为 "nearest"。
}
  • behavior表示滚动方式。auto表示使用当前元素的scroll-behavior样式。instantsmooth表示直接滚到底使用平滑滚动
  • block表示块级元素排列方向要滚动到的位置。对于默认的writing-mode: horizontal-tb来说,就是竖直方向。start表示将视口的顶部和元素顶部对齐;center表示将视口的中间和元素的中间对齐;end表示将视口的底部和元素底部对齐;nearest表示就近对齐。
  • inline表示行内元素排列方向要滚动到的位置。对于默认的writing-mode: horizontal-tb来说,就是水平方向。其值与block类似。

scrollIntoView 浏览器兼容性

分享一个页面平滑滚动小技巧(推荐)

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3条纹背景制作的实战攻略
May 31 HTML / CSS
CSS3 不定高宽垂直水平居中的几种方式
Mar 26 HTML / CSS
socket.io 和canvas 实现的共享画板功能
May 22 HTML / CSS
HTML5所有标签汇总及标签意义解释
Mar 12 HTML / CSS
HTML5新特性之用SVG绘制微信logo
Feb 03 HTML / CSS
HTML5 画布canvas使用方法
Mar 18 HTML / CSS
深入解析HTML5 Canvas控制图形矩阵变换的方法
Mar 24 HTML / CSS
canvas实现圆形进度条动画的示例代码
Dec 26 HTML / CSS
移动端开发HTML5页面点击按钮后出现闪烁或黑色背景的解决办法
Sep 19 HTML / CSS
html5实现滑块功能之type=&quot;range&quot;属性
Feb 18 HTML / CSS
带你了解CSS基础知识,样式
Jul 21 HTML / CSS
CSS中妙用 drop-shadow 实现线条光影效果
Nov 11 HTML / CSS
分享一个H5原生form表单的checkbox特效代码
Feb 26 #HTML / CSS
利用HTML5+css3+jquery+weui实现仿微信聊天界面功能
Jan 08 #HTML / CSS
canvas基础之图形验证码的示例
Jan 02 #HTML / CSS
HTML5实现分享到微信好友朋友圈QQ好友QQ空间微博二维码功能
Jan 03 #HTML / CSS
html5 canvas绘制放射性渐变色效果
Jan 04 #HTML / CSS
html5中如何将图片的绝对路径转换成文件对象
Jan 11 #HTML / CSS
详解Html5原生拖拽操作
Jan 12 #HTML / CSS
You might like
第九节--绑定
2006/11/16 PHP
使用PHP批量生成随机用户名
2008/07/10 PHP
php文件上传后端处理小技巧
2016/05/22 PHP
[原创]php求圆周率的简单实现方法
2016/05/30 PHP
深入理解PHP的远程多会话调试
2017/09/21 PHP
JavaScript 类的定义和引用 JavaScript高级培训 自定义对象
2010/04/27 Javascript
jquery 插件学习(二)
2012/08/06 Javascript
jquery+json实现数据列表分页示例代码
2013/11/15 Javascript
ztree获取当前选中节点子节点id集合的方法
2015/02/12 Javascript
自制微信公众号一键排版工具
2016/09/22 Javascript
你不知道的 javascript【推荐】
2017/01/08 Javascript
mui back 返回刷新页面的实例
2017/12/06 Javascript
JS+HTML实现的圆形可点击区域示例【3种方法】
2018/08/01 Javascript
微信小程序实现无限滚动列表
2020/05/29 Javascript
JS实现的合并两个有序链表算法示例
2019/02/25 Javascript
你或许不知道的一些npm实用技巧
2019/07/04 Javascript
基于better-scroll 实现歌词联动功能的代码
2020/05/07 Javascript
如何在JavaScript中使用localStorage详情
2021/02/04 Javascript
Python pass 语句使用示例
2014/03/11 Python
Python编码类型转换方法详解
2016/07/01 Python
python调用webservice接口的实现
2019/07/12 Python
python通过SSH登陆linux并操作的实现
2019/10/10 Python
德国鞋子网上商店:Omoda.de
2017/03/31 全球购物
linux下进程间通信的方式
2013/01/23 面试题
国际政治个人自荐信范文
2013/11/26 职场文书
报纸媒体创意广告词
2014/03/17 职场文书
2014年入党积极分子党课学习心得体会模板
2014/04/03 职场文书
城管年度个人总结
2015/02/28 职场文书
商务英语求职信范文
2015/03/19 职场文书
2015年监理个人工作总结
2015/05/23 职场文书
现货白银电话营销话术
2015/05/29 职场文书
电影雷锋观后感
2015/06/10 职场文书
2016年“5.12”护士节致辞
2015/07/31 职场文书
sql通过日期判断年龄函数的示例代码
2021/07/16 SQL Server
关于springboot 配置date字段返回时间戳的问题
2021/07/25 Java/Android
virtualenv隔离Python环境的问题解析
2022/06/21 Python