js原生写滚动条效果
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>仿浏览器滚动条</title>
<style type="text/css">
* {
margin: 0;
padding: 0;
}
#demo {
width: 300px;
height: 500px;
border: 1px solid red;
margin: 100px;
position: relative;
overflow: hidden;
}
p {
padding: 5px 20px 5px 5px;
font-size: 26px;
position: relative;
}
#scrll {
width: 18px;
border-radius: 18px;
position: absolute;
top: 0;
right: 0;
background: red;
cursor: pointer;
}
</style>
</head>
<body>
<div id="demo">
<p id="dp">我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容我是文字内容</p>
<div id="scrll"></div>
</div>
</body>
<script type="text/javascript">
(function(window) {
function $(id) {
return document.getElementById(id);
};
// 获取对象
var dp = $("dp"),
demo = $("demo"),
scrll = $("scrll");
// 获取dp的长度
var dpHeight = dp.offsetHeight;
// 获取demo的长度
var demoHeight = demo.offsetHeight;
// 根据比值计算scrll的长度
var scrllHeight = demoHeight * demoHeight / dpHeight;
// 如果内容长度小于窗口长度,则滚动条不显示
if (dp.offsetHeight < demo.offsetHeight) {
scrllHeight = 0;
};
scrll.style.height = scrllHeight + "px";
// 获取滚动条和内容移动距离的比例
var bilu = (dp.offsetHeight - demo.offsetHeight) / (demo.offsetHeight - scrll.offsetHeight);
// 滚动条滚动事件
scrll.onmousedown = function(event) {
// event兼容性解决
// console.log(demo.offsetTop)
var event = event || window.event;
// 获取鼠标按下的页面坐标
// 滚动条滚动时只有top值改变,所有不需要获取pageX
var pageY = event.pageY || event.clientY + document.documentElement.scrollTop;
// 获取鼠标在scrll内的坐标
var scrllY = pageY - demo.offsetTop - scrll.offsetTop;
// 给document绑定鼠标移动事件
document.onmousemove = function(event) {
var event = event || window.event;
// 获取鼠标移动时的坐标
var moveY = event.pageY || event.clientY + document.documentElement.scrollTop;
// 获取滚动条的移动坐标
var trueY = moveY - scrllY - demo.offsetTop;
// 限制滚动条移动的范围
if (trueY < 0) {
trueY = 0;
};
if (trueY > demo.offsetHeight - scrll.offsetHeight) {
trueY = demo.offsetHeight - scrll.offsetHeight;
};
scrll.style.top = trueY + "px";
//清除选中文字
window.getSelection ? window.getSelection().removeAllRanges() : document.selection.empty();
// 获取文字区域移动的距离
var dpY = trueY * bilu;
dp.style.top = -dpY + "px";
}
};
// 鼠标抬起清除鼠标移动事件
document.onmouseup = function() {
document.onmousemove = null;
}
})(window)
</script>
</html>
本文来自博客园,作者:JackieDYH,转载请注明原文链接:https://www.cnblogs.com/JackieDYH/p/17634763.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现