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


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 相关文章推荐
收集的7个CSS3代码生成工具
Apr 17 HTML / CSS
css3 transform属性详解
Sep 30 HTML / CSS
推荐一些比较有用的css3新属性
Nov 11 HTML / CSS
CSS3制作苹果风格键盘特效
Feb 26 HTML / CSS
canvas绘制文本内容自动换行的实现代码
Jan 14 HTML / CSS
HTML5标签小集
Aug 02 HTML / CSS
HTML5之SVG 2D入门12—SVG DOM及DOM操作介绍
Jan 30 HTML / CSS
html5使用canvas压缩图片的示例代码
Sep 11 HTML / CSS
使用canvas压缩图片上传的方法示例
Feb 07 HTML / CSS
HTML5中在title标题标签里设置小图标的方法
Jun 23 HTML / CSS
CSS3常见动画的实现方式
Apr 14 HTML / CSS
基于CSS3画一个iPhone
Apr 21 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
用PHP函数解决SQL injection
2006/12/09 PHP
第七章 php自定义函数实现代码
2011/12/30 PHP
window.onload 加载完毕的问题及解决方案(下)
2009/07/09 Javascript
JS 实现双色表格实现代码
2009/11/24 Javascript
JavaScript操作Oracle数据库示例
2015/03/06 Javascript
JS脚本根据手机浏览器类型跳转WAP手机网站(两种方式)
2015/08/04 Javascript
AngularJs学习第五篇从Controller控制器谈谈$scope作用域
2016/06/08 Javascript
javascript稀疏数组(sparse array)和密集数组用法分析
2016/12/28 Javascript
Javascript封装id、class与元素选择器方法示例
2017/03/13 Javascript
React.Js添加与删除onScroll事件的方法详解
2017/11/03 Javascript
通过jquery获取上传文件名称、类型和大小的实现代码
2018/04/19 jQuery
vue中axios请求的封装实例代码
2019/03/23 Javascript
JavaScript JSON使用原理及注意事项
2020/07/30 Javascript
pycharm 使用心得(九)解决No Python interpreter selected的问题
2014/06/06 Python
一个基于flask的web应用诞生 组织结构调整(7)
2017/04/11 Python
python anaconda 安装 环境变量 升级 以及特殊库安装的方法
2017/06/21 Python
浅谈python 线程池threadpool之实现
2017/11/17 Python
python向已存在的excel中新增表,不覆盖原数据的实例
2018/05/02 Python
python 实现selenium断言和验证的方法
2019/02/13 Python
python中的print()输出
2019/04/12 Python
django foreignkey外键使用的例子 相当于left join
2019/08/06 Python
Python利用PyExecJS库执行JS函数的案例分析
2019/12/18 Python
Python中的X[:,0]、X[:,1]、X[:,:,0]、X[:,:,1]、X[:,m:n]和X[:,:,m:n]
2020/02/13 Python
Python通过正则库爬取淘宝商品信息代码实例
2020/03/02 Python
浅谈django框架集成swagger以及自定义参数问题
2020/07/07 Python
Python之字典添加元素的几种方法
2020/09/30 Python
如何基于Python按行合并两个txt
2020/11/03 Python
Python 中的函数装饰器和闭包详解
2021/02/06 Python
html5实现多文件的上传示例代码
2014/02/13 HTML / CSS
世界最大的海报和艺术印刷商店:AllPosters.com
2017/02/01 全球购物
简单的JAVA编程面试题
2013/03/19 面试题
国际贸易专业推荐信
2013/11/15 职场文书
病人家属写给医院的感谢信
2015/01/23 职场文书
导游词怎么写
2015/02/04 职场文书
安全教育的主题班会
2015/08/13 职场文书
《月歌。》宣布制作10周年纪念剧场版《RABBITS KINGDOM THE MOVIE》
2022/04/02 日漫