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


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 background-image颜色渐变的实现代码
Sep 13 HTML / CSS
一款纯css3实现的鼠标经过按钮特效教程
Nov 09 HTML / CSS
css3实现3d旋转动画特效
Mar 10 HTML / CSS
css3实现wifi信号逐渐增强效果实例
Aug 09 HTML / CSS
html5 touch事件实现页面上下滑动效果【附代码】
Mar 10 HTML / CSS
HTML5边玩边学(2)基础绘图实现方法
Sep 21 HTML / CSS
用HTML5实现手机摇一摇的功能的教程
Oct 30 HTML / CSS
html5文字阴影效果text-shadow使用示例
Jul 25 HTML / CSS
使用HTML5的File实现base64和图片的互转
Aug 01 HTML / CSS
HTML5中的autofocus(自动聚焦)属性介绍
Apr 23 HTML / CSS
HTML5实现移动端复制功能
Apr 19 HTML / CSS
如何在Canvas中添加事件的方法示例
May 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
基于curl数据采集之单页面并行采集函数get_htmls的使用
2013/04/28 PHP
PHP实现Soap通讯的方法
2014/11/03 PHP
PHP程序员常见的40个陋习,你中了几个?
2014/11/20 PHP
PHP获取音频文件的相关信息
2015/06/22 PHP
PHP优化之批量操作MySQL实例分析
2020/04/23 PHP
actionscript与javascript的区别
2011/05/25 Javascript
jquery 无限级联菜单案例分享
2013/03/26 Javascript
jQuery.holdReady()方法用法实例
2014/12/27 Javascript
JQuery中上下文选择器实现方法
2015/05/18 Javascript
jQuery实现分隔条左右拖动功能
2015/11/21 Javascript
小巧强大的jquery layer弹窗弹层插件
2015/12/06 Javascript
js仿百度登录页实现拖动窗口效果
2016/03/11 Javascript
jQuery插件FusionCharts实现的3D柱状图效果实例【附demo源码下载】
2017/03/03 Javascript
JS 判断某变量是否为某数组中的一个值的3种方法(总结)
2017/07/10 Javascript
Angular 5.0 来了! 有这些大变化
2017/11/15 Javascript
webpack external模块的具体使用
2018/03/10 Javascript
微信小程序网络请求封装示例
2018/07/24 Javascript
在微信小程序中渲染HTML内容3种解决方案及分析与问题解决
2020/01/12 Javascript
react 原生实现头像滚动播放的示例
2020/04/21 Javascript
JS+CSS实现过渡特效
2021/01/02 Javascript
[48:20]OpTic vs Serenity 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
python处理圆角图片、圆形图片的例子
2014/04/25 Python
Python中的日期时间处理详解
2016/11/17 Python
Python实现在线音乐播放器
2017/03/03 Python
理解Python中的绝对路径和相对路径
2017/08/30 Python
Anaconda2下实现Python2.7和Python3.5的共存方法
2018/06/11 Python
python gdal安装与简单使用
2019/08/01 Python
基于python解线性矩阵方程(numpy中的matrix类)
2019/10/21 Python
Python如何用filter函数筛选数据
2020/03/05 Python
python读取mysql数据绘制条形图
2020/03/25 Python
利用keras使用神经网络预测销量操作
2020/07/07 Python
Python urlopen()参数代码示例解析
2020/12/10 Python
德国大型箱包和皮具商店:Koffer
2019/10/01 全球购物
Linux面试题LINUX系统类
2014/11/19 面试题
房屋授权委托书范本
2014/10/07 职场文书
写给同学的新学期寄语
2015/02/27 职场文书