JavaScript實(shí)現(xiàn)滑塊驗(yàn)證案例
本文實(shí)例為大家分享了JavaScript實(shí)現(xiàn)滑塊驗(yàn)證的具體代碼,供大家參考,具體內(nèi)容如下
<!DOCTYPE html> <html lang="en"> ? <head> ? ? <meta charset="UTF-8"> ? ? <meta http-equiv="X-UA-Compatible" content="IE=edge"> ? ? <meta name="viewport" content="width=device-width, initial-scale=1.0"> ? ? <title>Document</title> ? ? <style> ? ? ? ? * { ? ? ? ? ? ? margin: 0; ? ? ? ? ? ? padding: 0; ? ? ? ? } ? ? ? ? ? .box { ? ? ? ? ? ? position: relative; ? ? ? ? ? ? width: 500px; ? ? ? ? ? ? height: 40px; ? ? ? ? ? ? border: 1px solid #000; ? ? ? ? ? ?? ? ? ? ? } ? ? ? ? ? p { ? ? ? ? ? ? position: relative; ? ? ? ? ? ? z-index: 5; ? ? ? ? ? ? font: 20px/40px '楷體'; ? ? ? ? ? ? text-align: center; ? ? ? ? ? ? color: rgba(95, 90, 90, 0.479); ? ? ? ? } ? ? ? ? ? .btn { ? ? ? ? ? ? width: 40px; ? ? ? ? ? ? height: 40px; ? ? ? ? ? ? border: 1px solid #ccc; ? ? ? ? ? ? box-sizing: border-box; ? ? ? ? ? ? background-color: #fff; ? ? ? ? ? ? cursor: pointer; ? ? ? ? ? ? z-index: 6; ? ? ? ? ? ? position: absolute; ? ? ? ? ? ? top: 0; ? ? ? ? ? ? left: 0; ? ? ? ? ? ? background-position: center; ? ? ? ? ? ? background-repeat: no-repeat; ? ? ? ? ? ? background-size: 50% auto; ? ? ? ? ? ? background-image: url(./圖1.png); ? ? ? ? } ? ? ? ? ? .bg { ? ? ? ? ? ? height: 100%; ? ? ? ? ? ? position: absolute; ? ? ? ? ? ? top: 0; ? ? ? ? ? ? left: 0; ? ? ? ? ? ? background-color: #7ac23c; ? ? ? ? } ? ? </style> </head> ? <body> ? ? <div class="box"> ? ? ? ? <div class="btn"></div> ? ? ? ? <p>拖動(dòng)滑塊驗(yàn)證</p> ? ? ? ? <div class="bg"></div> ? ? </div> </body> <script> ? ? //獲取事件 ? ? var box = document.querySelector('.box') ? ? var p = document.querySelector('p') ? ? var btn = document.querySelector('.btn') ? ? var bg = document.querySelector('.bg') ? ? ? // 選中文字就會(huì)觸發(fā)這個(gè)事件 ? ? this.box.onselectstart = function () { ? ? ? ? return false // 阻止默認(rèn)行為 ? ? } ? ? //默認(rèn)沒有驗(yàn)證成功 ? ? var flag = false; ? ? //按下事件 ? ? btn.onmousedown = function () { ? ? ? ? var e1 = window.event; ? ? ? ? var x1 = e1.offsetX; ? ? ? ? //移動(dòng)事件 ? ? ? ? btn.onmousemove = function () { ? ? ? ? ? ? var e2 = window.event; ? ? ? ? ? ? var x2 = e2.clientX ? ? ? ? ? ? //計(jì)算left的值 ? ? ? ? ? ? var left = x2 - x1 ? ? ? ? ? ? if (left > 0) { ? ? ? ? ? ? ? ? //設(shè)置滑動(dòng)塊的距離 ? ? ? ? ? ? ? ? this.style.left = left + 'px'; ? ? ? ? ? ? ? ? //設(shè)置背景的寬度 ? ? ? ? ? ? ? ? bg.style.width = left + 'px'; ? ? ? ? ? ? ? ? if (left > box.offsetWidth - this.offsetWidth) { ? ? ? ? ? ? ? ? ? ? //驗(yàn)證成功 ? ? ? ? ? ? ? ? ? ? flag = true; ? ? ? ? ? ? ? ? ? ? p.innerText = '通過驗(yàn)證' ? ? ? ? ? ? ? ? ? ? p.style.color = '#000' ? ? ? ? ? ? ? ? ? ? //事件清除 ? ? ? ? ? ? ? ? ? ? this.onmousedown = null; ? ? ? ? ? ? ? ? ? ? this.onmousemove = null; ? ? ? ? ? ? ? ? ? } ? ? ? ? ? ? } ? ? ? ? } ? ? ? ? ? ? //鼠標(biāo)松開 ? ? ? ? btn.onmouseup = function () { ? ? ? ? ? ? //事件清除 ? ? ? ? ? ? this.onmousemove = null; ? ? ? ? ? ? //判斷驗(yàn)證是否成功 ? ? ? ? ? ? if (flag) { ? ? ? ? ? ? ? ? return ? ? ? ? ? ? } ? ? ? ? ? ? this.style.left = 0; //設(shè)置滑動(dòng)塊的距離 ? ? ? ? ? ? bg.style.width = 0; //設(shè)置背景的寬度 ? ? ? ? }; ? ? } </script> ? </html>
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript canvas復(fù)刻蘋果發(fā)布會(huì)環(huán)形進(jìn)度條
canvas 真是一個(gè)好東西,它給前端插上了想象的翅膀,伴隨著 h5 而來,將 web 代入了新的領(lǐng)域。本文將利用anvas復(fù)刻蘋果發(fā)布會(huì)環(huán)形進(jìn)度條,感興趣的可以嘗試一下2022-07-07js實(shí)現(xiàn)兼容IE6與IE7的DIV高度
兼容IE6與IE7的DIV高度的js代碼,2010-05-05JS實(shí)現(xiàn)判斷有效的數(shù)獨(dú)算法示例
這篇文章主要介紹了JS實(shí)現(xiàn)判斷有效的數(shù)獨(dú)算法,結(jié)合實(shí)例形式分析了javascript數(shù)獨(dú)判斷的原理及相關(guān)算法實(shí)現(xiàn)、使用操作技巧,需要的朋友可以參考下2019-02-02微信小程序scroll-view的滾動(dòng)條設(shè)置實(shí)現(xiàn)
這篇文章主要介紹了微信小程序scroll-view的滾動(dòng)條設(shè)置實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03原生js實(shí)現(xiàn)拖拽移動(dòng)與縮放效果
這篇文章主要為大家詳細(xì)介紹了原生js實(shí)現(xiàn)拖拽移動(dòng)與縮放效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08javascript 中事件冒泡和事件捕獲機(jī)制的詳解
這篇文章主要介紹了javascript 中事件冒泡和事件捕獲機(jī)制的詳解的相關(guān)資料,網(wǎng)上的相關(guān)資料有很多,但是講的不是多清楚,通過本文希望能讓大家理解掌握,需要的朋友可以參考下2017-09-09微信小程序?qū)崿F(xiàn)注冊(cè)登錄功能(表單校驗(yàn)、錯(cuò)誤提示)
這篇文章主要介紹了微信小程序 實(shí)現(xiàn)注冊(cè)、登錄功能(表單校驗(yàn)、錯(cuò)誤提示),本文通過代碼給大家詳細(xì)介紹,需要的朋友可以參考下2019-12-12