• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    分享一个页面平滑滚动小技巧(推荐)

    背景

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

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

    正文

    有几种不同的方式来解决这个小问题。

    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,元素的顶端将和其所在滚动区的可视区域的顶端对齐。

    如果为false,元素的底端将和其所在滚动区的可视区域的底端对齐。

    {
        behavior: "auto" | "instant" | "smooth", 默认为 "auto"。
        block: "start" | "end", 默认为 "start"。
        inline: "start"| "center"| "end", | "nearest"。默认为 "nearest"。
    }

    scrollIntoView 浏览器兼容性

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

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

    上一篇:IE9下html5初试小刀
    下一篇:HTML5: Web 标准最巨大的飞跃
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

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