您现在的位置是:网站首页> 编程资料编程资料
分享一个页面平滑滚动小技巧(推荐)详解三种方式实现平滑滚动页面到顶部的功能css隐藏移动端滚动条并且ios上平滑滚动的方法
2021-08-29
1617人已围观
简介 这篇文章主要介绍了分享一个页面平滑滚动小技巧(推荐),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
背景
今天写需求的时候发现一个小的优化点:用户选择了一些数据之后, 对应列表中的数据需要高亮, 有时候列表很长, 为了提升用户体验,需要加个滚动, 自动滚动到目标位置。
简单的处理了一下, 问题顺利解决, 就把这个小技巧分享一下给大家。
正文
有几种不同的方式来解决这个小问题。
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上, 网页默认滚动是在标签上的,移动端大多数在
标签上, 那么这行定义到全局的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, 问题完美解决。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关内容
- css3制作的背景渐变动画效果css3实现背景图片半透明内容不透明的方法示例css3实现背景图片颜色修改的多种方式CSS3实现模糊背景的三种效果示例CSS3 菱形拼图实现只旋转div 背景图片不旋转功能CSS3只让背景图片旋转180度的实现示例基于css3制作的圆形透明画中画视频播放特效JS+CSS3文章内容背景黑白切换特效代码css3实现简单的白云飘动背景特效CSS3 实现的动态星空背景
- css 中多种边框的实现小窍门一文教你玩转CSS border(边框)CSS 奇思妙想边框动画效果的实现CSS3 按钮边框动画的实现CSS3 实现发光边框特效两款纯CSS3鼠标经过按钮边框动画特效一篇文章带你学习CSS3图片边框css3多种边框悬停按钮填色动画特效css 透明边框background-clip妙用CSS3实现缺角矩形,折角矩形以及缺角边框CSS边框长度控制功能的实现
- 使用Html+Css实现简易导航栏功能(导航栏遇到鼠标切换背景颜色)使用HTML+Css+transform实现3D导航栏的示例代码html+css+js实现导航栏滚动渐变效果Html5导航栏吸顶方案原理与对比实现html5 横向滑动导航栏的方法示例html+css 实现简易导航栏功能基于html和CSS3制作简单侧边导航栏基于html和CSS3制作酷炫的导航栏
- html+css 实现简易导航栏功能HTML+CSS 实现顶部导航栏菜单制作CSS 带搜索导航栏的示例代码html+css+js实现导航栏滚动渐变效果纯CSS实现导航栏下划线跟随的示例代码CSS+HTML 实现顶部导航栏功能
- css3实现的天气图标动画效果CSS3 实现的定价表纯CSS3精美3D卡片翻转动画特效css3 filter属性的使用简介CSS3点击按钮圆形进度打钩效果的实现代码CSS3实现模糊背景的三种效果示例CSS3通过var()和calc()函数实现动画特效CSS3 菱形拼图实现只旋转div 背景图片不旋转功能CSS3实现的六边形波纹加载动画特效源码基于js+css3文章列表喜欢点赞按钮特效源码
- 纯 CSS 实现点击展开阅读全文功能JS和CSS3实现点击展开页面动画特效
- CSS实现两个元素相融效果(粘滞效果)css将两个元素水平对齐的方法(兼容IE8)
- css为什么要放在head标签中html5+css3之制作header实例与更新html5+css3之CSS中的布局与Header的实现
- animation和transition的区别css transition animation的使用(内含贝赛尔曲线详解)css动画属性使用及实例代码(transition/transform/animation) 使用CSS transition和animation改变渐变状态的实现方法CSS3与动画有关的属性transition、animation、transform对比(史上最全CSS3中动画属性transform、transition和animation属性的区别
- 详解CSS标签模式display属性一文了解CSS 标签显示模式详解CSS标签中的显示模式浅析css中使用border属性与display属性的方法详解css display:box 新属性浅谈CSS3中display属性的Flex布局的方法浅谈CSS的Display属性可能的值CSS display属性的table表格布局
