<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>自定义滚动条</title>
<style type="text/css">
#div1 {
    width: 20px;
    height: 400px;
    position: relative;
    background: black;
    margin: 5px auto;
    left: 200px;
}

#div2 {
    width: 20px;
    height: 20px;
    position: absolute;
    background: green;
}

#div3 {
    width: 300px;
    height: 300px;
    position: relative;
    overflow: hidden;
    top: -320px;
    border: 1px solid black;
    background-color:green;
}

#div4 {
    position: absolute;
    left: 0;
    top: -20px;
    padding: 4px;
}
</style>
<script type="text/javascript">
    window.onload = function() {
        var oDiv = document.getElementById('div1');
        var oDiv2 = document.getElementById('div2');
        var oDiv3 = document.getElementById('div3');
        var oDiv4 = document.getElementById('div4');
        var disY = 0;
        oDiv.onmousedown = function(ev) {
            var oEvent = ev || event;
            //Div距离 ClientX-Left
            disY = oEvent.clientY - oDiv2.offsetTop;
            if (oDiv2.setCapture) {
                //IE
                oDiv2.onmousemove = function(ev) {
                    var oEvent = ev || event;
                    var y = oEvent.clientY - disY;
                    //下拉
                    var scale = y / (oDiv.offsetHeight - oDiv2.offsetHeight);
                    //        document.title =scale;
                    //磁铁吸附
                    if (scale < 0) {
                        scale = 0;
                    } else if (scale > 1) {
                        scale = 1;
                    }
                    if (y < 0) {
                        y = 0;
                    } else if (y > oDiv.offsetHeight - oDiv2.offsetHeight) {
                        y = oDiv.offsetHeight - oDiv2.offsetHeight;
                    }
                    oDiv2.style.top = y + 'px';
                    oDiv4.style.top = -(oDiv4.offsetHeight - oDiv3.offsetHeight)
                            * scale + 'px';

                };
                oDiv2.onmouseup = function() {
                    oDiv2.onmousemove = null;
                    oDiv2.onmouseup = null;

                    oDiv2.releaseCapture();
                };

                oDiv2.setCapture();
            } else {
                //Chrome FF
                oDiv2.onmousemove = function(ev) {
                    var oEvent = ev || event;
                    var y = oEvent.clientY - disY;
                    if (y < 0) {
                        y = 0;
                    } else if (y > Div2.offsetHeight - oDiv.offsetHeight) {
                        y = Div2.offsetHeight - oDiv.offsetHeight;
                    }
                    oDiv2.style.top = y + 'px';
                };
                document.onmouseup = function() {
                    document.onmousemove = null;
                    document.onmouseup = null;

                };

            }
            //阻止浏览器的默认拖拽
            return false;
        };

    };
</script>
</head>
<body>
    <div id="div1" title="我是素材">
        <div id="div2" title="我是下拉线"></div>
    </div>
    <div id="div3" title="我是下拉框">
        <div id="div4">来自意大利时尚之都米兰的地标建筑“垂直森林”来到了中国。据美媒boredpanda2月6日报道,“垂直森林之父”为斯特凡诺·博埃里(Stefano
            Boeri),而南京“垂直森林”项目为亚洲首座博埃里设计在建的“垂直森林”建筑。

            报道称,此项建筑将由656英尺(约200米)及354英尺(约108米)的双塔楼组成,外围覆盖至少1000棵树以及约2500棵灌木类植物。“垂直森林”每天可以消化二氧化碳,并释放132磅(约60千克)的氧气。来自意大利时尚之都米兰的地标建筑“垂直森林”来到了中国。据美媒boredpanda2月6日报道,“垂直森林之父”为斯特凡诺·博埃里(Stefano
            Boeri),而南京“垂直森林”项目为亚洲首座博埃里设计在建的“垂直森林”建筑。

            报道称,此项建筑将由656英尺(约200米)及354英尺(约108米)的双塔楼组成,外围覆盖至少1000棵树以及约2500棵灌木类植物。“垂直森林”每天可以消化二氧化碳,并释放132磅(约60千克)的氧气。来自意大利时尚之都米兰的地标建筑“垂直森林”来到了中国。据美媒boredpanda2月6日报道,“垂直森林之父”为斯特凡诺·博埃里(Stefano
            Boeri),而南京“垂直森林”项目为亚洲首座博埃里设计在建的“垂直森林”建筑。

            报道称,此项建筑将由656英尺(约200米)及354英尺(约108米)的双塔楼组成,外围覆盖至少1000棵树以及约2500棵灌木类植物。“垂直森林”每天可以消化二氧化碳,并释放132磅(约60千克)的氧气。来自意大利时尚之都米兰的地标建筑“垂直森林”来到了中国。据美媒boredpanda2月6日报道,“垂直森林之父”为斯特凡诺·博埃里(Stefano
            Boeri),而南京“垂直森林”项目为亚洲首座博埃里设计在建的“垂直森林”建筑。

            报道称,此项建筑将由656英尺(约200米)及354英尺(约108米)的双塔楼组成,外围覆盖至少1000棵树以及约2500棵灌木类植物。“垂直森林”每天可以消化二氧化碳,并释放132磅(约60千克)的氧气。
        </div>
    </div>
</body>
</html>

自定义滚动条Js简版的更多相关文章

  1. js简版定时器

    <html> <head> <meta http-equiv="Content-Type" content="text/html; char ...

  2. js 简版双色球 取号

    <style type="text/css"> span{ display: block; float: left; width: 50px; height: 50px ...

  3. 基于React.js网页版弹窗|react pc端自定义对话框组件RLayer

    基于React.js实现PC桌面端自定义弹窗组件RLayer. 前几天有分享一个Vue网页版弹框组件,今天分享一个最新开发的React PC桌面端自定义对话框组件. RLayer 一款基于react. ...

  4. 利用JS实现自定义滚动条

    一般默认的滚动条会比较丑,我们可以用简单的js实现自定义滚动条的功能: 代码如下: <!doctype html> <html> <head> <meta c ...

  5. js消除小游戏(极简版)

    js小游戏极简版 (1) 基础布局 <div class = "box"> <p></p> <div class="div&qu ...

  6. js自定义滚动条

    今天听到别人说自定义滚动条,所以就在吃饭的时间写了个 html部分 <div class="out" id="out"> <div class ...

  7. css和js实现硬件加速渲染自定义滚动条

    听别人说用CSS的变换来实现渲染有硬件加速的效果,看到很多大网站都开始陆续使用上了,我也来说说怎么做,我这边实现的滚动条有自然滚动效果,看起来比较自然,说的再多不如直接写,让我们开始吧! 我们需要自己 ...

  8. Vue.js 桌面端自定义滚动条组件|vue美化滚动条VScroll

    基于vue.js开发的小巧PC端自定义滚动条组件VScroll. 前段时间有给大家分享一个vue桌面端弹框组件,今天再分享最近开发的一个vue pc端自定义滚动条组件. vscroll 一款基于vue ...

  9. 自定义滚动条 - mCustomScrollbar

    项目中需要使用自定义滚动条,但是试用了很多都功能不够全,今天发现一个比较全而且用法很简单的 -- mCustomScrollbar http://manos.malihu.gr/jquery-cust ...

随机推荐

  1. Cocos2dx 学习笔记整理----开发环境搭建

    最近在学习cocos2dx,预备将学习过程整理成笔记. 需要的工具和环境整理一下: 使用的版本 cocos2dx目前已经出到了v3.1.1,学习和项目的话还是用2.2.3为宜,毕竟不大想做小白鼠,并且 ...

  2. MySQL的 explain 解析

    EXPLAIN 的每个输出行提供一个表的相关信息,并且每个行包括下面的列: 项 说明 id MySQL Query Optimizer 选定的执行计划中查询的序列号.表示查询中执行 select 子句 ...

  3. python继承的实例

    class SchoolMember(object):#定义学校 member=0#默认成员为0个 amount=0#默认学费为0元 def __init__(self,name,age,sex):# ...

  4. APP被苹果APPStore拒绝的各种原因 分类: ios相关 app相关 2015-06-25 17:27 200人阅读 评论(0) 收藏

    APP被苹果APPStore拒绝的各种原因 1.程序有重大bug,程序不能启动,或者中途退出. 2.绕过苹果的付费渠道,我们之前游戏里的用兑换码兑换金币. 3.游戏里有实物奖励的话,一定要说清楚,奖励 ...

  5. SRM 592 DIV2 报告

    昨天下午查看邮箱,看到了topcoder的SRM比赛通知和cf的比赛通知,当时什么也不想做,心里空荡荡的,忽然就想参加一下,试试看.吃完晚饭回来一看,就剩十几分钟了,匆忙把平台下了,就开始等待比赛开始 ...

  6. xml的生成和发送

    s2014-04-07 10:01:05 之前学的是解析,现在需要生成xml, 然后利用蓝牙或者wifi发送到服务器 2014-04-07 10:36:34 采用dom4j创建xml报错 后来发现安卓 ...

  7. iOS 之 手势

    手势操作,有一个总的抽象类UIGestureRecognizer,用于检测设备的所有手势.其下有多个子类: 拍击UITapGestureRecognizer (任意次数的拍击) 向里或向外捏UIPin ...

  8. Jquery知识小点备注

    jQuery siblings() 方法返回被选元素的所有同胞元素,并且可以使用可选参数来过滤对同胞元素的搜索. 实例演示:点击某个li标签后将其设置为红色,而其所有同胞元素去除红色样式 创建Html ...

  9. var d = document.getElementById 错误

    var d = document.getElementById; var s = d("demo").innerHTML; alert(s); // IE 没有问题,其他浏览器必须 ...

  10. ANT编译时执行Junit测试

    1.Junit.jar(和jakarta-ant-optional.jar 不是必须) 放在ant_home/lib中,用于支持build.xml中的<junit>标签 2.修改build ...