您现在的位置是:网站首页> 编程资料编程资料
详解如何用div实现自制滚动条div的滚动条如何实现css将div层固定显示在页面底部不随滚动条滚动给DIV添加滚动条的实现代码给div加滚动条 div显示滚动条设置代码css实现div自动添加滚动条(图片或文字等超出时显示)div css 滚动条样式 DIV滚动条属性及样式设置方式
2021-09-04
1224人已围观
简介 这篇文章主要介绍了详解如何用div实现自制滚动条,滚动条是浏览器中最常见的组件了。想要学习如何自制滚动条的方法,需要了解的朋友可以参考下
滚动条是浏览器中最常见的组件了。然而,滚动条的颜值总是不能令人满意,特别是嵌入在页面中的滚动条:

漂亮的网页突然出现一根灰灰的滚动条真是太煞风景了。虽然浏览器也提供了一些伪类能改善滚动条的外观,但改善程度也是有限。为什么不自己用 div 实现一根萌萌的滚动条呢,比如这根:

贪吃蛇滚动条
今天就来讲讲如何用 div 自己实现滚动条。
1. 先得有滚动条
在开始之前,我们要先隐藏浏览器本身的滚动条,加上自制的滚动条
bla bla bla ... 一大段一屏显示不下的内容
我们在需要滚动条的 div 中增加了一个 class="scroll" 的 div 代表滚动条,给这个 div 来点样式:
html, body, #container { height: 100%; margin: 0; } #container { padding: 2rem; box-sizing: border-box; // 为了设置padding时不增加元素本身高度,避免出现滚动条 overflow-y: hidden; // 隐藏浏览器本身的滚动条 position: relative; padding-right: 30px; // 给自制滚动条留点空间,不要其他内容重合了 } .scrollbar { height: 166px; width: 20px; border-radius: 20px; background: #ccc; position: absolute; // 绝对定位,方便设置滚动条位置 right: 0; // 设置滚动条在最右边 } 一个简易的滚动条就有了:

虽然比浏览器默认的滚动条好不到哪儿去,不过你可以自由发挥,把GIF动图作为滚动条也是可以的。由于滚动条是 absolute 定位的,后面就通过 top 属性来控制滚动条的位置。
现在滚动条还是静态的,想要让他动起来,就要先了解下滚动条与文档滚动的关系。
2. 滚动条与文档滚动的关系
先看这张图

蓝色框代表一个很长的文档,文档的高度可以通过 scrollHeight 属性获得。
屏幕一下子显示不了那么多内容,只能显示红色区域部分,红色区域就称为”视口“(Viewport),视口的高度可以通过 offsetHeight 属性获得。
页面刚加载时,视口的顶部和文档顶部是重合的,滚动条(绿色竖条)也在最顶部。当我们将滚动条下拉时,文档的内容在向上滚动,其实是视口在向下移动:

视口向下移动后,与文档顶部就有了个偏移,这个偏移可以通过 scrollTop 获得。视口下移的同时,滚动条与顶部也有一段距离了,暂且用 h 表示。
视口里文档顶部的最大距离可以是多少?根据图可以看出是 scrollHeight - offsetHeight;类似地,滚动条最大可以滚动的距离是 offsetHeight - barHeight,其中 barHeight 是滚动条本身的高度。
看到这里你是否有些明白了,滚动条滚动的距离,与文档视口离开顶部的距离是成一定比例的。滚动条滑动多少距离,文档视口就按比例滑动多少距离。而这个比例值就等于:
ratio = (scrollHeight - offsetHeight) / (offsetHeight - barHeight)
假设文档总长 5000px,视口高度1080px,滚动条滑块高 40px,那么根据公式计算出比例值是 3.77。也就是说,滚动条每滚动 1px,视口就要下移 3.77px
利用这个比例值,我们就可以让滚动条和视口等比例地进行滑动了。
3. 通过JavaScript控制滚动条
在自制的滚动条中,滚动通过两种事件触发,我们需要自己处理事件:
- 鼠标滚轮滚动时,更新视口位置,同时按比例更新滚动条的位置
- 鼠标拖拽滚动条时,更新滚动条位置,同时按比例更新视口位置
3.1 鼠标滚轮事件
鼠标滚轮滚动时,会触发 mousewheel 事件,此时需要根据滚动增量(e.deltaY)更新视口位置,在根据新的视口位置推算出滚动条的位置。代码:
container.addEventListener('mousewheel', function(e) { this.scrollTop += e.deltaY; this.scrollbar.style.top = (this.scrollTop + this.scrollTop / this.ratio) + 'px'; }); 可以看到,滚动条的 top 值就是当前视口的偏移(scrollTop)加上这个偏移的按比例缩小。
3.2 鼠标拖拽事件
JavaScript 原生没有拖拽事件,需要用左键点下(mousedown),鼠标移动(mousemove),左键放开(mouseup)三个事件配合模拟出拖拽效果:
container.addEventListener('mousedown', function (e) { if (e.target === this.scrollbar) { this.prevY = e.pageY; } }); container.addEventListener('mouseup', function (e) { this.prevY = null; }); container.addEventListener('mousemove', function (e) { if (this.prevY) { // 此时可以确定用户在表示拖拽 } e.preventDefault(); }); 上面的代码在处理 mousemove 事件时使用 e.preventDefault() 阻止浏览器默认动作,您可以自行尝试加上和不加这行的效果。接着上面的代码,我们处理拖拽动作:
if (this.prevY) { // 此时可以确定用户在表示拖拽 this.scrollTop += (e.pageY - this.prevY) * this.ratio; this.scrollbar.style.top = (this.scrollTop + this.scrollTop / this.ratio) + 'px'; this.prevY = e.pageY; } 与滚轮滚动不同,JavaScript没有给出每次拖拽的移动增量,需要自己计算,并每次存储上一次的鼠标位置。
至此一个可用的自制滚动条就完成了。
完整代码
Document bla, bla, bla... 一大段很长的文字
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关内容
- css3 边框、背景、文本效果的实现代码基于CSS 属性实现按钮悬停边框和背景动画集合CSS 制作带边框背景色透明的消息框CSS3实现多背景模拟动态边框的效果CSS控制背景图像平铺实现边框阴影效果css div 边框阴影利用背景图或内外层div实现层次感觉阴影效果css样式div或li在ie6下背景平铺及border边框断线解决技巧 CSS新特性:圆角边框多栏Gird布局背景设置css背景和边框标签实例详解
- CSS 图片动画特效的示例代码(相框)CSS相框效果示例代码CSS伪元素before、after设置特殊效果:制作时尚焦点图相框
- css多行文本溢出时出现省略号的示例纯CSS定制文本省略的方法大全css3实现渐变、阴影、超出指定文本省略号显示等一些效果实例CSS实现标题文字过长部分显示省略号的方法CSS样式 解决文字过长显示省略号问题
- 分享CSS书写规范、顺序【推荐大家使用】CSS代码书写规范究极指南Discuzx系统 CSS 编码规范、CSS属性书写顺序CSS书写规范、顺序和命名规则书写CSS的5个小技巧让你的样式更规范CSS XTHML书写规范以及常见问题总结(页面最优化)web开发中怎么样使css书写规范? CSS 的加载及加载顺序简介详解CSS中的选择器优先级顺序解决CSS3的opacity属性带来的层叠顺序问题深入解析CSS中z-index属性对层叠顺序的处理
- 浅谈CSS层叠机制CSS样式继承和层叠css照片有如层叠效果的实现方法浅谈CSS中的继承性,特殊性,层叠性和重要性CSS特殊性、继承与层叠解决CSS3的opacity属性带来的层叠顺序问题深入理解CSS定位与层叠详解CSS中的z-index属性在层叠布局中的用法深入解析CSS中z-index属性对层叠顺序的处理详解CSS的结构与层叠以及格式化权重和层叠规则决定了CSS样式优先级
- 详解css display:box 新属性一文了解CSS 标签显示模式详解CSS标签中的显示模式浅析css中使用border属性与display属性的方法浅谈CSS3中display属性的Flex布局的方法浅谈CSS的Display属性可能的值CSS display属性的table表格布局详解CSS标签模式display属性
- 浅谈CSS浮动的特性Css实现清除浮动的方法汇总深入理解CSS overflow:hidden——溢出,坍塌,清除浮动CSS清除浮动方法大全(小结)CSS3 清除浮动的方法示例深入理解css布局之定位与浮动CSS实现元素浮动和清除浮动的方法
- 前端应该掌握的CSS实现多列等高布局技巧css设置多列等高布局的方法示例利用CSS3的flexbox实现水平垂直居中与三列等高布局浅析CSS等高布局的6种方式用CSS实现三列DIV等高布局以传达更好的视觉效果多列等高的CSS实现代码CSS 三栏等高布局实现方法CSS实例:CSS实现的等高网页布局CSS实例:三列等高布局-CSS教程-网页制作-网页教学网css多种方式实现等高布局的示例代码
- 使用CSS和Bootstrap图标制作上下跳动的指示箭头动画效果纯CSS制作各种各样的网页图标(三角形、暂停按钮、下载箭头、加号等)CSS制作箭头图标代码(圆,三角形,椭圆) css实现的交互小三角箭头图标纯CSS实现箭头、气泡让提示功能具有三角形图标CSS多级数字序号的目录列表(2.2.1. 2.2.2 列表序号)GitHub倡导的CSS编写风格及文件目录部署指南完美解决调用上级目录中的css样式文件的路径问题CSS拾遗之箭头,目录,图标的实现代码
- 纯HTML和CSS实现JD轮播图效果HTML5轮播图全代码
