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

2020-04-21 22:41:17易采站长站整理

背景

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

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

正文

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

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