亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript實(shí)現(xiàn)滑塊驗(yàn)證案例

 更新時(shí)間:2022年01月13日 08:40:22   作者:HAI6545  
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)滑塊驗(yàn)證案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(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)文章

最新評(píng)論