zoukankan      html  css  js  c++  java
  • 原生js实现拖动滑块验证

    拖动滑块验证是现在的网站随处可见的,各式各样的拖动法都有。

    下面实现的是某宝的拖动滑块验证:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <style type="text/css">
            .drag{position: relative;width: 300px;height: 34px;background-color: #e8e8e8;line-height: 34px;}
            .bg{position: absolute;width: 40px;height: 100%;background-color: #7ac23c;}
            .text{position: absolute;width: 100%;margin: 0;text-align: center;}
            .btn{position: absolute;width: 40px;height: 32px;background: #fff url() center no-repeat;border: 1px solid #ccc;cursor: pointer;}
        </style>
    </head>
    <body>
        <div class="drag">
            <div class="bg"></div>
            <p class="text">拖动滑块验证</p>
            <div class="btn"></div>
        </div>
    
        <script>
            var $ = function(selector){
                return document.querySelector(selector);
            },
            box = $('.drag'),//容器
            bg = $('.bg'),//绿色背景
            text = $('.text'),//文字
            btn = $('.btn'),//拖动按钮
            done = false;//是否通过验证
    
            btn.onmousedown = function(e){
                var e = e || window.event;
                var posX = e.clientX - this.offsetLeft;
    
                btn.onmousemove = function(e){
                    var e = e || event;
    
                    var x = e.clientX - posX;
    
                    this.style.left = x + 'px';
                    bg.style.width = this.offsetLeft + 'px';
    
                    // 通过验证
                    if(x >= box.offsetWidth - btn.offsetWidth){
                        done = true;
                        btn.onmousedown = null;
                        btn.onmousemove = null;
                        text.innerHTML = '通过验证';
                    }
                };
    
                document.onmouseup = function(){
                    btn.onmousemove = null;
                    btn.onmouseup = null;
    
                    if(done)return;
                    btn.style.left = 0;
                    bg.style.width = 0;
                }
            };
    
            text.onmousedown = function(){
                return false;
            }
        </script>
    </body>
    </html>

    由于是原生js实现的,因此没有加上动画效果,不然代码量太大。

    代码简单,直接看下结构就明了了。

  • 相关阅读:
    MapReduce -- 统计天气信息
    设计模式--策略模式
    基于物品的协同过滤(二)
    Hadoop应用开发,常见错误
    基于物品的协同过滤(一)
    基于用户的协同过滤
    MapReduce开发程序,运行环境配置
    3DES加解密 C语言
    js获取对象位置的方法
    icheck.js的一个简单demo
  • 原文地址:https://www.cnblogs.com/11lang/p/6819142.html
Copyright © 2011-2022 走看看