原生Js常见业务练习(1)—— 滑块验证

文章目录


滑块验证

效果如下:

结合当下流行的验证方式:滑块验证、图片滑块验证、验证码验证等...

今日份练习:滑块验证,旨在对原生JavaScript网页交互进行复习与巩固,废话不多说,上代码:

html部分

<!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>Slider validation</title>
    <link rel="stylesheet" href="./css/Slider_validation.css">
</head>

<body>
    <div id="dragContainer">    <!--滑块验证容器 -->
        <div id="dragBg"></div>     <!--滑块左侧部分 -->
        <div id="dragText"></div>       <!--容器文本 -->
        <div id="dragHandler" class="dargHandlerBg"></div>      <!--滑块 -->
    </div>
    <script src="./js/Slider_validation.js"></script>
</body>

</html>

css部分

/* 滑块验证容器 */
#dragContainer {
    position: relative;
    display: inline-block;    /* 转行内块元素 */
    background: #e8e8e8;
    width: 300px;
    height: 33px;
    border: 2px solid #e8e8e8;
}

/* 滑块左侧部分绿色背景 */
#dragBg {
    position: absolute;
    background-color: #7ac23c;
    width: 0px;
    height: 100%;
}

/* 滑块验证容器文字 */
#dragText {
    position: absolute;
    width: 100%;
    height: 100%;
    text-align: center;
    line-height: 33px;
    /* 文字不允许选中 */
    user-select: none;
}

#dragHandler {
    position: absolute;
    width: 40px;
    height: 100%;
    cursor: move;
}

/* 滑块初始化背景 */
.dargHandlerBg {
    background: #fff no-repeat center url("");
}

/* 滑块成功时的背景 */
.dargHandlerOkBg {
    background: #fff no-repeat center url("");
}

JavaScript部分

window.onload = function () {
  let dragContainer = document.querySelector('#dragContainer')
  let dragBg = document.querySelector('#dragBg')
  let dragText = document.querySelector('#dragText')
  let dragHandler = document.querySelector('#dragHandler')
  // 滑块最大偏移量 = 滑块验证容器长度 - 滑块长度
  let maxHandlerOffset = dragContainer.clientWidth - dragHandler.clientWidth
  // 是否验证成功标记
  let isVertifySuccess = false
  initDrag()
  function initDrag() {
    dragText.textContent = '拖动滑块验证'
    // 滑块设置鼠标按下监听
    dragHandler.addEventListener('mousedown', onDragHandlerDown)
  }
  
  function onDragHandlerDown() {
    document.addEventListener('mousemove', onDragHandlerMove)
    document.addEventListener('mouseup', onDragHandlerUp)
  }

  function onDragHandlerMove(e) {
    // clientX 属性返回鼠标指针的水平坐标(根据当前窗口)
    let left = e.clientX - dragHandler.clientWidth / 2
    if (left < 0) {
      left = 0
    } else if (left > maxHandlerOffset) {
      left = maxHandlerOffset
    }
    dragHandler.style.left = left + 'px'
    dragBg.style.width = dragHandler.style.left
  }

  function onDragHandlerUp(e) {
    document.removeEventListener('mousemove', onDragHandlerMove)
    let left = e.clientX - dragHandler.clientWidth / 2
    if (left >= maxHandlerOffset) {
      vertifySuccess()
    } else {
      // 初始化滑块移动量
      dragHandler.style.left = 0
      dragBg.style.width = 0
    }
  }

  // 验证成功
  function vertifySuccess() {
    isVertifySuccess = true
    dragText.textContent = '验证通过'
    dragText.style.color = 'white'
    dragHandler.setAttribute('class', 'dargHandlerOkBg')
    dragHandler.removeEventListener('mousedown', onDragHandlerDown)
    document.removeEventListener('mousemove', onDragHandlerMove)
    document.removeEventListener('mouseup', onDragHandlerUp)
    // 设置跳转
    window.location.href =
      'https://blog.csdn.net/m0_53375764?spm=1000.2115.3001.5343'
  }
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JV_32

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值