1. 程式人生 > >原生js實現拖動滑塊驗證

原生js實現拖動滑塊驗證

cnblogs tcc mvt wms 網站 hnu 按鈕 itl rip

拖動滑塊驗證是現在的網站隨處可見的,各式各樣的拖動法都有。

下面實現的是某寶的拖動滑塊驗證:

<!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實現的,因此沒有加上動畫效果,不然代碼量太大。

代碼簡單,直接看下結構就明了了。

原生js實現拖動滑塊驗證