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


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仿造window7的开始菜单
Jun 17 HTML / CSS
使用CSS3的appearance属性改变任何元素的浏览器默认风格
Dec 24 HTML / CSS
CSS3制作ajax loader icon实现思路及代码
Aug 25 HTML / CSS
CSS3实现伪类hover离开时平滑过渡效果示例
Aug 10 HTML / CSS
HTML5实现QQ聊天气泡效果
Jun 26 HTML / CSS
HTML5 Canvas鼠标与键盘事件demo示例
Jul 04 HTML / CSS
html5开发之viewport使用
Oct 17 HTML / CSS
利用HTML5 Canvas制作一个简单的打飞机游戏
May 11 HTML / CSS
Web时代变迁及html5与html4的区别
Jan 06 HTML / CSS
详解移动端HTML5页面端去掉input输入框的白色背景和边框(兼容Android和ios)
Dec 15 HTML / CSS
html5开发三八女王节表白神器
Mar 07 HTML / CSS
HTML5中使用json对象的实例代码
Sep 10 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脚本数据库功能详解(中)
2006/10/09 PHP
如何删除多级目录
2006/10/09 PHP
PHP 和 XML: 使用expat函数(三)
2006/10/09 PHP
Javascript YUI 读码日记之 YAHOO.util.Dom - Part.2 0
2008/03/22 Javascript
JavaScript this调用规则说明
2010/03/08 Javascript
浅谈Javascript事件处理程序的几种方式
2012/06/27 Javascript
Jquery 过滤器(first,last,not,even,odd)的使用
2014/01/22 Javascript
如何用jquery控制表格奇偶行及活动行颜色
2014/04/20 Javascript
对比分析json及XML
2014/11/28 Javascript
Jquery搜索父元素操作方法
2015/02/10 Javascript
js制作带有遮罩弹出层实现登录注册表单特效代码分享
2015/09/05 Javascript
jquery pagination插件动态分页实例(Bootstrap分页)
2016/12/23 Javascript
Django与Vue语法的冲突问题完美解决方法
2017/12/14 Javascript
JavaScript的级联函数用法简单示例【链式调用】
2019/03/26 Javascript
浅谈Vue 自动化部署打包上线
2020/06/14 Javascript
vue3.0实现插件封装
2020/12/14 Vue.js
[06:24]DOTA2亚洲邀请赛小组赛第三日 TOP10精彩集锦
2015/02/01 DOTA
使用PDB简单调试Python程序简明指南
2015/04/25 Python
Python字典操作详细介绍及字典内建方法分享
2018/01/04 Python
Python实现将照片变成卡通图片的方法【基于opencv】
2018/01/17 Python
python hbase读取数据发送kafka的方法
2018/12/27 Python
使用Python-OpenCV向图片添加噪声的实现(高斯噪声、椒盐噪声)
2019/05/28 Python
Python内置random模块生成随机数的方法
2019/05/31 Python
Python用字典构建多级菜单功能
2019/07/11 Python
解决Django中调用keras的模型出现的问题
2019/08/07 Python
Python批量安装卸载1000个apk的方法
2020/04/10 Python
CSS3教程:background-clip和background-origin
2008/10/17 HTML / CSS
耐克波兰官方网站:Nike波兰
2019/09/03 全球购物
印度在线购买电子产品网站:Croma
2020/01/02 全球购物
Java Servlet API中forward() 与redirect()的区别
2014/04/20 面试题
优秀求职自荐信怎样写
2013/12/18 职场文书
经典团队口号
2014/06/06 职场文书
会计学习心得体会
2014/09/09 职场文书
pycharm debug 断点调试心得分享
2021/04/16 Python
CSS 实现多彩、智能的阴影效果
2021/05/12 HTML / CSS
python高温预警数据获取实例
2022/07/23 Python