原生JS实现拖拽进度条显示相应的内容

原生JS实现拖拽进度条显示相应的内容今天要分享的是运用原生JS实现拖拽进度条显示相应的内容,效果如下:以下是代码实现,欢迎大家复制粘贴。<!DOCTYPEhtml><html><head><metahttp-equiv=”Content-Type”content=”text/html;charset=utf-8″/><title&………

今天要分享的是运用原生JS实现拖拽进度条显示相应的内容,效果如下:

原生JS实现拖拽进度条显示相应的内容

以下是代码实现,欢迎大家复制粘贴。

<!DOCTYPE html>
<html>

<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>原生JS实现拖拽进度条显示相应的内容</title>
    <style>
        #slider {
            width: 400px;
            height: 20px;
            background: #CCC;
            position: relative;
            margin: 20px auto;
        }

        #block {
            width: 20px;
            height: 20px;
            background: red;
            cursor: pointer;
            position: absolute;
        }

        #box {
            width: 200px;
            height: 300px;
            margin: 0 auto;
            border: 1px solid black;
            position: relative;
            overflow: hidden;
        }

        #content {
            position: absolute;
        }
    </style>

</head>

<body>

    <div id="slider">
        <div id="block"></div>
    </div>

    <div id="box">

        <div id="content">

            关于我们

            我们是一支独具特色的IT培训团队,反对传统IT教育枯燥
            乏味的教学模式,提供一种全新的快乐学习方法!

            目前主要针对的是JavaScript培训,同时还提供了css教程、JavaScript
            视频、JavaScript特效等,最新推出了外地学员们喜欢的JavaScript网络课程服
            务,同时还为处于JavaScript入门阶段的朋友录制了大量JavaScript视
            频,其中涉及了大量JavaScript基础知识,希望我们推出的JavaScript
            网络培训课程能带给大家更多惊喜。

            关于讲师:

            我们的讲师来自中国最具吸引力的IT企业,如淘宝、ShopEx等。
            前端开发讲师:Augus WEB 前端开发工程师(5年)、CSS 精品课
            程讲师(3年),公司创始人;曾任北京科尔威视、ShopEx 北京营
            销中心 ECMall 项目前端架构师;精通 XHTML+CSS 架构,深刻理解
            W3C 标准,熟练掌握系统的浏览器兼容性解决方案,擅长大型网站前
            端架构及调试各类页面错位等诸多兼容性问题的疑难杂症;专注于网站
            用户体验性研究,并在视频、电子商城、教育平台、企业级应用站点拥
            有数量庞大的案例和多年实战经验;
        </div>

    </div>

    <script>


        window.onload = function () {

            var slider = document.getElementById('slider');
            var block = document.getElementById('block');

            var box = document.getElementById('box');
            var content = document.getElementById('content');

            block.onmousedown = function (ev) {

                var myEvent = ev || event;

                // 计算鼠标相对滑块上的位置
                var disX = myEvent.clientX - block.offsetLeft;
                document.onmousemove = function (ev) {
                    var myEvent = ev || event;
                    // 计算滑块的动态left值
                    var l = myEvent.clientX - disX;

                    // 限制拖拽范围
                    if (l < 0) {
                        l = 0;
                    } else if (l > slider.offsetWidth - block.offsetWidth) {
                        l = slider.offsetWidth - block.offsetWidth;
                    };

                    block.style.left = l + 'px';

                    // 计算拖拽移动距离与可拖动总范围的比例
                    var scale = l / (slider.offsetWidth - block.offsetWidth);

                    // 让content跟随鼠标的滑动追逐渐滚动内容
                    content.style.top = -(content.offsetHeight - box.offsetHeight) * scale + 'px';

                };

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


    </script>

</body>

</html>

今天的文章原生JS实现拖拽进度条显示相应的内容分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/29317.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注