zoukankan      html  css  js  c++  java
  • js-实现常见的拖拽效果(表单滑块验证)

    本文将详细介绍拖拽的实现过程,会使用到js的三个事件(鼠标按下mousedown、鼠标移动mousemove、鼠标抬起mouseup),利用这三个事件即可完成拖拽效果。

    在没有拖拽到最右端的情况下,会自动返回,效果图如下:

    具体实现代码如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
        <style>
            div{
                 300px;
                height: 30px;
                margin: 40px auto;
                border: 1px #eee solid;
                position: relative;
            }
            p{
                padding: 0;
                margin: 0;
                float: left;
                height: 30px;
                background: yellow;
            }
            span{
                float: left;
                 30px;
                height: 30px;
                text-align: center;
                line-height: 30px;
                background-color: violet;
                position: absolute;
                cursor: pointer;;
            }
        </style>
    </head>
    <body>
        <div>
            <p></p><span>>></span>
        </div>
    </body>
    <script src="../move.js"></script>
    <script>
        class tz{
            constructor(){
                this.div = document.querySelector('div');
                this.p = document.querySelector('p');
                this.span = document.querySelector('span');
                this.init();
            }
            init(){
                // 鼠标按下记录坐标
                this.span.onmousedown = (eve)=>{
                    var e = eve || window.event;
                    this.left = e.offsetX;
                    // 鼠标按下之后执行后面的鼠标移动和鼠标抬起
                    this.move();
                    this.up();
                }
            }
            // 鼠标移动事件
            move(){
                var that = this;
                document.onmousemove = function(eve){
                    var e = eve || window.event;                
                    that.l = e.pageX- that.div.offsetLeft - that.left;
                    if(that.l<0){that.l=0};
                    if(that.l > that.div.offsetWidth - that.span.offsetWidth){
                        that.l = that.div.offsetWidth - that.span.offsetWidth;
                        that.span.innerHTML = '√';
                    }
                    that.span.style.left = that.l + 'px';
                    that.p.style.width = that.l + 'px';
                    return false;
                }
            }
            // 鼠标抬起事件
            up(){
                document.onmouseup = ()=>{
                    document.onmousemove=null;
                    document.onmouseup = null;
                    if(this.l< this.div.offsetWidth - this.span.offsetWidth){
                        move(this.span,{left:0});
                        move(this.p,{0});
                    }
                }
            }
        }
        new tz();
    </script>
    </html>
     
     
    如果有什么疑问,请在评论区留言
  • 相关阅读:
    LOJ#3157. 「NOI2019」机器人 DP+拉格朗日插值
    BZOJ4832 [Lydsy2017年4月月赛]抵制克苏恩 记忆化搜索
    LazySysAdmin 靶机渗透
    zico2靶机渗透
    6_面向对象-下之关键字:static
    5_面向对象-中之单元测试方法、包装类的使用
    5_面向对象-中之Object类的使用
    5_面向对象-中之面向对象的特征三:多态性
    5_面向对象-中之子类对象实例化全过程
    5_面向对象-中之关键字:super
  • 原文地址:https://www.cnblogs.com/piaoyi1997/p/12996368.html
Copyright © 2011-2022 走看看