js div自制滚动条

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link type="text/css" rel="stylesheet" href="../css/reset.css"/>
    <style>
        .box{
            width: 400px;
            height: 500px;
            border: 1px solid red;
            margin: 100px;
            overflow: hidden;
            position: relative;
        }
        .content{
            padding: 5px 18px 5px 5px;
            text-indent: 2em;
            font-size: 15px;
            position: absolute;
            top: 0;
            left: 0;
        }
        .scroll{
            width: 18px;
            height: 100%;
            background-color: #eeeeee;
            position: absolute;
            right: 0;
            top: 0;
        }
        .scroll .bar{
            display: inline-block;
            border-radius: 8px;
            width: 18px;
            background-color: red;
            position: absolute;
            top: 0;
            left: 0;
        }
    </style>
</head>
<body>
<div id="box" class="box">
    <div class="content">
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳
        飞雪连天射白鹿 笑书神侠倚碧鸳 飞雪连天射白鹿 笑书神侠倚碧鸳11
    </div>
    <div class="scroll">
        <span class="bar"></span>
    </div>
  <script>
      function returnId(id) {
          return document.getElementById(id);
      }
      //外层盒子对象
      var box = returnId("box");
      //内容对象
      var content =box.children[0];
      //滚动条盒子对象
      var scroll = box.children[1];
      //滚动条对象
      var bar = scroll.children[0];

      //初始化滚动条高度
      //外层盒子高度/内容高度 = 滚动条高度/滚动条盒子高度
      //滚动条高度 = 外层盒子高度*滚动条盒子高度/内容高度
      var height = box.offsetHeight * scroll.offsetHeight / content.offsetHeight;
      bar.style.height = height+"px";

      //滚动条移动
      //触发按下滚动条事件
      bar.onmousedown = function (ev) {
          //求出按下区域与滚动条最上边距离
          var space = window.event?window.event.clientY-bar.offsetTop:ev.clientY-bar.offsetTop;
          document.onmousemove = function (ev2) {
              //求出滚动条此时距离滚动条盒子高度的距离
              //求出滚动条此时距离滚动条盒子高度的距离 = 此时可以区域距离 - 按下区域与滚动条最上边距离
              var y = window.event?window.event.clientY-space:ev2.clientY-space;
              y = y<0?0:y;//不让滚动条移动到外面去
              y = y>scroll.offsetHeight:y-bar.offsetHeight?scroll.offsetHeight:y-bar.offsetHeight:y;
              bar.style.top = y+"px";
              //内容移动
              //滚动条移动距离/滚动条最大移动距离 = 内容移动距离/内容最大移动距离
              var contentY = y*(content.offsetHeight-box.offsetHeight)/(scroll.offsetHeight-bar.offsetHeight);
              content.style.top = -contentY+"px";
              //设置鼠标移动的时候,文字不被选中 //ie支持document.selection
                window.getSelection? window.getSelection().removeAllRanges():document.selection.empty();
          };
      };
      document.onmouseup = function () {
          document.onmousemove = null;
      };

  </script>
</div>
</body>
</html>

实现效果
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值