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


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动画效果
Aug 14 HTML / CSS
基于CSS3的CSS 多栏(Multi-column)实现瀑布流源码分享
Jun 11 HTML / CSS
CSS3的Flexbox布局的简明入门指南
Apr 08 HTML / CSS
html5触摸事件判断滑动方向的实现
Jun 05 HTML / CSS
html5调用摄像头功能的实现代码
May 07 HTML / CSS
HTML5 File API改善网页上传功能
Aug 19 HTML / CSS
html5时钟实现代码
Oct 22 HTML / CSS
HTML5中实现拖放效果无须借助javascript
Dec 26 HTML / CSS
HTML5图片预览实例分享
Jun 04 HTML / CSS
html5响应式开发自动计算fontSize的方法
Jan 13 HTML / CSS
在HTML中引入CSS的几种方式介绍
Dec 06 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 数据库字段复用的基本原理与示例
2011/07/22 PHP
PHP 正则表达式常用函数
2014/08/17 PHP
Laravel框架数据库CURD操作、连贯操作总结
2014/09/03 PHP
PHP利用Socket获取网站的SSL证书与公钥
2017/06/18 PHP
PHP 爬取网页的主要方法
2018/07/13 PHP
用Javascript做flash做的事..才完成的一个类.Auntion Action var 0.1
2007/02/23 Javascript
javascript 判断数组是否已包含了某个元素的函数
2010/05/30 Javascript
jquery DIV撑大让滚动条滚到最底部代码
2013/06/06 Javascript
基于jQuery实现的扇形定时器附源码下载
2015/10/20 Javascript
理解Javascript的call、apply
2015/12/16 Javascript
js时间戳转为日期格式的方法
2015/12/28 Javascript
轻松搞定jQuery.noConflict()
2016/02/15 Javascript
图文详解JavaScript的原型对象及原型链
2016/08/02 Javascript
微信小程序 slider 详解及实例代码
2017/01/10 Javascript
详解Sea.js中Module.exports和exports的区别
2017/02/12 Javascript
Web开发中客户端的跳转与服务器端的跳转的区别
2017/03/05 Javascript
纯js实现页面返回顶部的动画(超简单)
2017/08/10 Javascript
基于vue的换肤功能的示例代码
2017/10/10 Javascript
解决vue-cli脚手架打包后vendor文件过大的问题
2018/09/27 Javascript
angularJs使用ng-repeat遍历后选中某一个的方法
2018/09/30 Javascript
js前端面试之同步与异步问题详解
2019/04/03 Javascript
ES6 Array常用扩展的应用实例分析
2019/06/26 Javascript
VUE的history模式下除了index外其他路由404报错解决办法
2019/08/21 Javascript
layui form.render('select', 'test2') 更新渲染的方法
2019/09/27 Javascript
CKEditor扩展插件:自动排版功能autoformat插件实现方法详解
2020/02/06 Javascript
python数据结构学习之实现线性表的顺序
2018/09/28 Python
torch 中各种图像格式转换的实现方法
2019/12/26 Python
使用pyecharts1.7进行简单的可视化大全
2020/05/17 Python
cosme官方海外旗舰店:日本最大化妆品和美容产品的综合口碑网站
2017/01/18 全球购物
Zavvi美国:英国娱乐之家
2017/03/19 全球购物
APM Monaco中国官网:来自摩纳哥珠宝品牌
2017/12/27 全球购物
DIY手工制作经营店创业计划书
2014/02/01 职场文书
计算机网络工程专业职业生涯规划书
2014/03/10 职场文书
证券公司客户经理岗位职责
2015/04/09 职场文书
超市主管竞聘书
2015/09/15 职场文书
Python MNIST手写体识别详解与试练
2021/11/07 Python