web前端怎么设计滚动文字区域(详解三种方式实现平滑滚动页面到顶部的功能)
web前端怎么设计滚动文字区域
详解三种方式实现平滑滚动页面到顶部的功能背景
最近开发公司的公众号H5,做了一个点击icon滚动到顶部的功能。实现功能比较简单,直接调用window.scrollTo(0, 0),一行代码完成。但是作为一个攻城狮,怎么可能对自己要求这么低,所以我给自己加了个需求,实现 平滑滚动页面到顶部 的功能。经过调研和查看文档,有了以下三种方案。
1.使用CSS
完成功能的最高境界,只用CSS就搞定。代码如下:
html { scroll-behavior: smooth; }
该样式的作用是为有滚动条的元素指定一个滚动的行为,但是只有在当用户手动导航或者 CSSOM scrolling API触发滚动的时候生效,不影响用户行为产生的滚动。就在我庆祝的时候,打开can i use看了下兼容性:
日了狗,还是老老实实用JS实现吧。
2.使用Window.scrollTo API
我们都知道window.scrollTo(x, y),通过传入文档中的x,y轴坐标来实现滚动到页面某个位置的功能。这个API其实还可以传入一个option,是一个对象,left值对应坐标中的x,top对应坐标中的y,还有一个值为behavior,可以让你自定义滚动行为,然后我们这样来实现滚动到顶部:
window.scrollTo({ left: 0, top: 0, behavior: 'smooth' })
真香,搞定。过了几天,产品经理扛着5米大刀来找我,说在Safari上滚动效果奇怪,体检极差。于是我默默打开了MDN文档,滚动到底部:
看到了这张图,虽然API浏览器都几乎支持,但是option选项在Safari上直接挂掉,于是我又打开了stackoverflow,总结了终极方案。
3.使用requestAnimationFrame
经常能看到大名鼎鼎的requestAnimationFrame,但是没机会用上,这次可以尝尝鲜了。我们知道requestAnimationFrame的作用就是告诉浏览器在下次重绘之前执行传入的回调函数,这个行为是浏览器自动帮你做的。于是有了如下代码:
const scrollToTop = () => { let scrollTop = document.documentElement.scrollTo || document.body.scrollTop if (scrollTop > 0) { window.requestAnimationFrame(scrollTop) window.scrollTop(0, scrollTop - scrollTo / 8) } }
Done!!!Perfect!!!雀跃的同时,我还是打开了can i use查看了requestAnimationFrame的兼容性:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
- css不显示滚动条设置(css隐藏移动端滚动条并且ios上平滑滚动的方法)
- 小程序ui设计样式(AmazeUI 平滑滚动效果的示例代码)
- web前端怎么设计滚动文字区域(详解三种方式实现平滑滚动页面到顶部的功能)
- 金品公司 界界乐中秋限定飞行棋礼盒 露营藤篮礼盒全新上市(界界乐中秋限定飞行棋礼盒)
- 必看 8月,相比七夕,更需要注意的是这些事(必看8月相比七夕)
- 8月23日11时16分将迎处暑,逐渐进入气象意义上的秋天(8月23日11时16分将迎处暑)
- 花不语 下 如果重来一次的话,你还会这么选择吗(花不语下如果重来一次的话)
- 城市记忆之上海 最难忘的是老弄堂里的市井味道(城市记忆之上海)
- 太鸡贼了,这老小区轻松搞定了停车问题(这老小区轻松搞定了停车问题)
热门推荐
- vue左右联动列表(vue+iview的菜单与页签的联动方式)
- jQuery给动态添加的元素绑定事件
- html5标签图片(HTML5图片层叠的实现示例)
- mysql查询很慢怎么回事(MySQL Like模糊查询速度太慢如何解决)
- 怎么查看python的安装路径(查看python安装路径及pip安装的包列表及路径)
- dedecms不生成文档(dedecms批量替换文章中超链接的方法)
- nodejs登录案例(利用Node.js创建一个密码生成器的全步骤)
- dedecms分页修改(Dedecms图片加上Alt和Title等属性的修改方法)
- vue 父组件传值(Vue两个同级组件传值实现)
- python爬取酷狗收费音乐(python爬取酷狗音乐排行榜)