背景
今天写需求的时候发现一个小的优化点:用户选择了一些数据之后, 对应列表中的数据需要高亮, 有时候列表很长, 为了提升用户体验,需要加个滚动, 自动滚动到目标位置。
简单的处理了一下, 问题顺利解决, 就把这个小技巧分享一下给大家。
正文
有几种不同的方式来解决这个小问题。
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
样式。instant
和smooth
表示直接滚到底
和使用平滑滚动
。block
表示块级元素排列方向要滚动到的位置。对于默认的writing-mode: horizontal-tb
来说,就是竖直方向。start
表示将视口的顶部和元素顶部对齐;center
表示将视口的中间和元素的中间对齐;end
表示将视口的底部和元素底部对齐;nearest
表示就近对齐。inline
表示行内元素排列方向要滚动到的位置。对于默认的writing-mode: horizontal-tb
来说,就是水平方向。其值与block
类似。
scrollIntoView 浏览器兼容性
最后我用的是 scrollIntoView
, 问题完美解决。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 顺子.2001-AND.MUSICS.THERE【EMI百代】【WAV+CUE】
- 《三国志8重置版》劝降机制介绍
- 《欢欣森活》最新官方配置要求一览
- 黑鸭子2012《印象江南》HQCD[日本版][WAV+CUE]
- 碧娜《温柔吻语》[WAV+CUE]
- MadeleinePeyroux-LetsWalk(2024)[FLAC][24B-96kHz]
- 纪钧瀚《舒眠心动钢琴曲 大提琴自然疗愈》[320K/MP3][140.28MB]
- 纪钧瀚《舒眠心动钢琴曲 大提琴自然疗愈》[FLAC/分轨][527.23MB]
- 张靓颖《UPDATE JANE》[低速原抓WAV+CUE][1G]
- 李克勤.2008-金碟铁盒珍藏系列李克勤【SONY】【WAV+CUE】
- 十个勤天.2024-故乡长卷【TME】【FLAC分轨】
- 林子祥.1983-爱情故事(2014K2HD限量版)【华纳】【WAV+CUE】
- 王杰2011《杰出精选.老歌回忆录HQ》[WAV分轨][1G]
- 龙梅子《情歌继续唱3》DSD[WAV+CUE][1.1G]
- 刘德华《劲歌集》24K金碟港版[WAV+CUE][1.2G]