全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JavaScript实现垂直滚动条效果

本文实例为大家分享了js垂直滚动条的实现代码,供大家参考,具体内容如下

1、红色盒子高度计算公式:

容器的高度 / 内容的高度 * 容器的高度

2、红色方块移动一像素 ,我们的内容盒子移动多少呢?

(内容盒子高度 - 大盒子高度) / (大盒子高度 - 红色盒子的高度) 计算倍数

(内容盒子高度 -  大盒子高度)/  (大盒子高度 - 红色盒子的高度)   * 红色盒子移动的数值

<html>
<head>
  <meta charset="UTF-8">
  <title>垂直滚动条</title>
  <style>
  *{
    padding: 0;
    margin: 0;
  }
    .box{
      width: 300px;
      height: 500px;
      border: 1px solid red;
      padding-right: 20px;
      margin: 100px;
      position: relative;
    }
    .content{
       padding: 5px 18px 10px 5px;
      position: absolute;
      left: 0;
      top: -10px;
    }
    .scroll{
      position: absolute;
      top: 0;
      right: 0;
      background-color: #ccc;
      width: 20px;
      height: 100%;
    }
    .bar{
      width: 100%;
      height: 20px;
      background-color: red;
      border-radius: 10px;
      position: absolute;
      left: 0;
      top: 0;
      cursor: pointer;
    }
  </style>  
</head>
<body>
  <div class="box" id="box">
    <div class="content">
      三观不同,一句话都嫌多。我想,人和人之间一定存在磁场这回事,沿着三观向外辐射。
   …………
 </div>
    <div class="scroll">
      <div class="bar"></div>
    </div>
  </div>
  <script>  
    var box = document.getElementById('box');
    var content = box.children[0];
    var scroll = box.children[1];
    var bar = scroll.children[0];
    //计算滚动条红色bar的长度:容器长度/内容长度 * 容器长度,,比例关系
    bar.style.height = box.offsetHeight / content.offsetHeight * box.offsetHeight +"px";
    bar.onmousedown = function(event){
      var event = event || window.event;
      var y = event.clientY - this.offsetTop;
      document.onmousemove = function(event){
        var event = event || window.event;

        var top = event.clientY - y;
        if(top < 0)
          top =0;
        else if(top > scroll.offsetHeight - bar.offsetHeight)
          top = scroll.offsetHeight - bar.offsetHeight;
        bar.style.top = top +"px";
        //(内容盒子高度 - 大盒子高度) / (大盒子高度 - 红色盒子的高度)  * 红色盒子移动的数值
        content.style.top = -(content.offsetHeight - box.offsetHeight)/(box.offsetHeight - bar.offsetHeight)*top+"px";

        window.getSelection ? window.getSelection().removeAllRanges() : document.selection.empty();  // 防止拖动滑块的时候, 选中文字
      }
    }
    document.onmouseup = function(){
      document.onmousemove = null;
    }
  </script>
</body>
</html> 

效果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# js垂直滚动条  # js滚动条  # js滚动条效果  # JS简单判断滚动条的滚动方向实现方法  # 原生js封装自定义滚动条  # js实现彩色条纹滚动条效果  # 原生js仿浏览器滚动条效果  # js实现简易垂直滚动条  # 基于JavaScript实现自定义滚动条  # js实现刷新页面后回到记录时滚动条的位置【两种方案可选】  # js 简易版滚动条实例(适用于移动端H5开发)  # 滚动条  # 我想  # 一句  # 拖动  # 这回  # 向外  # 大家分享  # 具体内容  # 话都  # 大家多多  # 计算公式  # 滑块  # width  # box  # px  # padding  # style  # title  # margin  # height 


相关文章: 如何规划企业建站流程的关键步骤?  深圳 网站制作,深圳招聘网站哪个比较好一点啊?  建站168自助建站系统:快速模板定制与SEO优化指南  视频网站app制作软件,有什么好的视频聊天网站或者软件?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  Python路径拼接规范_跨平台处理说明【指导】  ,交易猫的商品怎么发布到网站上去?  专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?  c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】  公司网站制作价格怎么算,公司办个官网需要多少钱?  建站之星展会模板:智能建站与自助搭建高效解决方案  网站制作模板下载什么软件,ppt模板免费下载网站?  网站好制作吗知乎,网站开发好学吗?有什么技巧?  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  高端建站如何打造兼具美学与转化的品牌官网?  大型企业网站制作流程,做网站需要注册公司吗?  大连网站设计制作招聘信息,大连投诉网站有哪些?  如何选择服务器才能高效搭建专属网站?  C++如何编写函数模板?(泛型编程入门)  建站之星2.7模板:企业网站建设与h5定制设计专题  建站之星在线版空间:自助建站+智能模板一键生成方案  宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?  如何选择高效响应式自助建站源码系统?  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  建站之星如何快速解决建站难题?  Swift开发中switch语句值绑定模式  常州自助建站费用包含哪些项目?  湖州网站制作公司有哪些,浙江中蓝新能源公司官网?  家庭服务器如何搭建个人网站?  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  如何快速辨别茅台真假?关键步骤解析  制作电商网页,电商供应链怎么做?  高防服务器如何保障网站安全无虞?  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?  英语简历制作免费网站推荐,如何将简历翻译成英文?  七夕网站制作视频,七夕大促活动怎么报名?  建站之星安装模板失败:服务器环境不兼容?  PHP正则匹配日期和时间(时间戳转换)的实例代码  建站之星安全性能如何?防护体系能否抵御黑客入侵?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  如何快速登录WAP自助建站平台?  盐城做公司网站,江苏电子版退休证办理流程?  ,如何利用word制作宣传手册?  独立制作一个网站多少钱,建立网站需要花多少钱?  建站之星会员如何解锁更多建站功能?  利用JavaScript实现拖拽改变元素大小  Android滚轮选择时间控件使用详解  如何用PHP快速搭建高效网站?分步指南  如何零基础开发自助建站系统?完整教程解析  如何在建站宝盒中设置产品搜索功能? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。