分享一个页面平滑滚动小技巧

背景

今天写需求的时候发现一个一个小的优化点:用户选择了一些数据以后, 选择的条目须要高亮, 有时候列表很长, 为了提高用户体验,须要加个滚动, 自动滚动到目标位置。css

下午简单的处理了一下, 问题顺利解决, 就把这个小技巧分享一下给你们。html

正文

有几种不一样的方式来解决这个小问题。前端

1.scrollTop

第一想到的仍是scrollTop, 获取元素的位置, 而后直接设置:浏览器

// 设置滚动的距离
element.scrollTop = value;

复制代码

不过这样子有点生硬, 能够加个缓动:bash

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上, 网页默认滚动是在标签上的,移动端大多数在 标签上, 那么这行定义到全局的css中就是:ui

html, body { 
  scroll-behavior:smooth; 
}
复制代码

美滋滋。spa

3. scrollIntoView

Element.scrollIntoView() 方法, 让当前的元素滚动到浏览器窗口的可视区域内。3d

语法:

var element = document.getElementById("box");

element.scrollIntoView(); // 等同于element.scrollIntoView(true) 
element.scrollIntoView(alignToTop); // Boolean型参数 
element.scrollIntoView(scrollIntoViewOptions); // Object型参数

复制代码

scrollIntoView 方法接受两种形式的值:

  1. 布尔值
  • 若是为true,元素的顶端将和其所在滚动区的可视区域的顶端对齐。
    • 相应的 scrollIntoViewOptions: {block: "start", inline: "nearest"}。这是这个参数的默认值。
  • 若是为false,元素的底端将和其所在滚动区的可视区域的底端对齐。
    • 相应的scrollIntoViewOptions: { block: "end", inline: "nearest" }
  1. Options 对象
{
    behavior: "auto" | "instant" | "smooth", 默认为 "auto"。
    block: "start" | "end", 默认为 "start"。
    inline: "start"| "center"| "end", | "nearest"。默认为 "nearest"。
}

复制代码
  1. behavior表示滚动方式。auto表示使用当前元素的scroll-behavior样式。instantsmooth表示直接滚到底使用平滑滚动
  2. block表示块级元素排列方向要滚动到的位置。对于默认的writing-mode: horizontal-tb来讲,就是竖直方向。start表示将视口的顶部和元素顶部对齐;center表示将视口的中间和元素的中间对齐;end表示将视口的底部和元素底部对齐;nearest表示就近对齐。
  3. inline表示行内元素排列方向要滚动到的位置。对于默认的writing-mode: horizontal-tb来讲,就是水平方向。其值与block相似。

scrollIntoView 浏览器兼容性

最后我用的是 scrollIntoView, 问题完美解决。

最后

没什么很新的东西, 就是介绍一下这个小技巧, 指望能给朋友们一点启发

若是以为内容有帮助能够关注下个人公众号 「 前端e进阶 」,一块儿学习。

clipboard.png
相关文章
相关标签/搜索