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


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 相关文章推荐
一款css实现的鼠标经过按钮的特效
Sep 11 HTML / CSS
CSS3实现文字波浪线效果示例代码
Nov 20 HTML / CSS
纯CSS3大转盘抽奖示例代码(响应式、可配置)
Jan 13 HTML / CSS
利用Bootstrap实现漂亮简洁的CSS3价格表实例源码
Mar 02 HTML / CSS
CSS3新增布局之: flex详解
Jun 18 HTML / CSS
css3实现简单的白云飘动背景特效
Oct 28 HTML / CSS
HTML5打开本地app应用的方法
Mar 31 HTML / CSS
html5拍照功能实现代码(htm5上传文件)
Dec 11 HTML / CSS
html5在移动端的屏幕适应问题示例探讨
Jun 15 HTML / CSS
html5录音功能实战示例
Mar 25 HTML / CSS
可能这些是你想要的H5软键盘兼容方案(小结)
Apr 23 HTML / CSS
CSS实现单选折叠菜单功能
Nov 01 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上传文件时自动分配路径的方法
2015/01/09 PHP
PHP+APACHE实现网址伪静态
2015/02/22 PHP
php版微信公众号接口实现发红包的方法
2016/10/14 PHP
accesskey 提交
2006/06/26 Javascript
IE与FireFox的兼容性问题分析
2007/04/22 Javascript
ext 代码生成器
2009/08/07 Javascript
禁止js文件缓存的代码
2010/04/09 Javascript
JS运行耗时操作的延时显示方法
2010/11/19 Javascript
关于锚点跳转及jQuery下相关操作与插件
2012/10/01 Javascript
javascript实现日历控件(年月日关闭按钮)
2012/12/12 Javascript
得到form下的所有的input的js代码
2013/11/07 Javascript
js的flv视频播放器插件使用方法
2015/06/23 Javascript
jQuery编程中的一些核心方法简介
2015/08/14 Javascript
表单验证插件Validation应用的实例讲解
2015/10/10 Javascript
JS中使用mailto实现将用户在网页中输入的内容传递到本地邮件客户端
2016/10/08 Javascript
javascript加载xml 并解析各节点的值(实现方法)
2016/10/12 Javascript
前端编码规范(3)JavaScript 开发规范
2017/01/21 Javascript
微信小程序 image组件binderror使用例子与js中的onerror区别
2017/02/15 Javascript
使用JavaScript实现表格编辑器(实例讲解)
2017/08/02 Javascript
ReactJs实现树形结构的数据显示的组件的示例
2017/08/18 Javascript
javaScript日期工具类DateUtils详解
2017/12/08 Javascript
vue+axios 前端实现登录拦截的两种方式(路由拦截、http拦截)
2018/10/24 Javascript
原生JS实现记忆翻牌游戏
2020/07/31 Javascript
[41:52]DOTA2-DPC中国联赛 正赛 CDEC vs Dynasty BO3 第二场 2月22日
2021/03/11 DOTA
Python定义函数功能与用法实例详解
2019/04/08 Python
基于python爬取梨视频实现过程解析
2020/11/09 Python
Python 利用Entrez库筛选下载PubMed文献摘要的示例
2020/11/24 Python
C/C++程序员常见面试题一
2012/12/08 面试题
测绘工程个人的自我评价
2013/11/23 职场文书
三万活动总结
2014/04/28 职场文书
党员干部批评与自我批评反四风思想汇报
2014/09/21 职场文书
2015年社区教育工作总结
2015/05/13 职场文书
化验室安全管理制度
2015/08/06 职场文书
PHP判断是否是json字符串
2021/04/01 PHP
Mysql服务添加 iptables防火墙策略的方案
2021/04/29 MySQL
MySQL库表太大怎么办? 数据库分库分表项目实践
2022/04/11 MySQL