原生JS实现移动端短信验证码功能

简介: 原生JS实现移动端短信验证码功能

实战效果演示:

实现原理:

  • 准备: 一个输入框, 四个div小盒子
  • 原理: 监听input输入框,分别让输入的四个数字展现在那四个小盒子里,在运用css知识,让四个小盒子覆盖输入框.

附上动画:

代码部分:

HTML

<div class="val-box" id="val-box">
    <input type="text" id="val-code-input" maxlength="4" onkeyup="checkNum(this)" onblur="checkNum(this)">
    <div name="val-item"></div>
    <div name="val-item"></div>
    <div name="val-item"></div>
    <div name="val-item"></div>
</div>

JS

首先聊聊 checkNum() 函数, 当我们输入验证码的时候,难免会有人输入一些非数字的字符进去, checkNum() 的作用就是将所有输入的不是数字的字符转换为空值.

function checkNum(e) {
    e.value = e.value.replace(/[\D]/g,'')
}

我们要做的第一步就是获取元素,数据初始化, 并且让用户一开始输入就去聚焦到输入框内.

const valBox = document.querySelector(".val-box")
// 输入框一被点击就聚焦到输入框
valBox.addEventListener("click", () => {
    console.log("聚焦");
    valCodeInput.focus()
})

第二步, 即时的反映输入框内的值

// 获取div小盒子
const valCodeItems = document.getElementsByName("val-item")
// 获取输入框
const valCodeInput = document.querySelector("#val-code-input")
const regex = /^[\d]+$/
// 验证码初始长度为0
let valCodeLength = 0
valCodeInput.addEventListener("input", (e) => {
    valCodeLength = valCodeInput.value.length
    // 如果输入的值符合要求
    if(valCodeInput.value && regex.test(valCodeInput.value)) {
        // 让div下边框边蓝
       valCodeItems[valCodeLength - 1].classList.add('available');
        // div的值与input的值相对应
        valCodeItems[valCodeLength - 1].innerText = valCodeInput.value.substring(valCodeLength - 1, valCodeLength)
    }
})
  • 点击获取验证码或点击第一个数字输入框时获取焦点, 并添加available 样式,使得第一个小盒子地边框边蓝
valCodeItems[0].addEventListener("click", (e) => {
    valCodeInput.focus()
    valCodeItems[0].classList.add("available")
})

第三步, 完善删除键,当删除键抬起的时候,删除最后一个小盒子内的数字,并去除下边框变蓝效果

window.addEventListener("keyup", (e) => {
    if(e.keyCode === 8) {
        valCodeItems[valCodeLength].innerText = ""
        if(valCodeLength !== 0) {
            valCodeItems[valCodeLength].classList.remove("available")
        }
    }
})

接下来就是最后一步啦, 当检测到输入框的长度变为4时,自动发送短信验证请求.

写在最后

  • 看到这里有没有收获什么呢?🎀🎀🎀
  • 🎈🎈有错误的地方可以在评论区留言,本博会虚心改正的

相关文章
|
3月前
|
JavaScript 前端开发
JavaScript分页功能
JavaScript分页功能
|
5天前
|
JavaScript 前端开发
【Vue.js】监听器功能(EventListener)的实际应用【合集】
而此次问题的核心就在于,Vue实例化的时机过早,在其所依赖的DOM结构尚未完整构建完成时就已启动挂载流程,从而导致无法找到对应的DOM元素,最终致使计算器功能出现异常,输出框错误地显示“{{current}}”,并且按钮的交互功能也完全丧失响应。为了让代码结构更为清晰,便于后续的维护与管理工作,我打算把HTML文件中标签内的JavaScript代码迁移到外部的JS文件里,随后在HTML文件中对其进行引用。
23 8
|
24天前
|
JavaScript 容器
带方向感知功能的js图片遮罩层插件
带方向感知功能的js图片遮罩层插件
|
2月前
|
JavaScript 前端开发 容器
jQuery多功能滑块插件r-slider.js
r-slider.js是一款jQuery多功能滑块插件。使用该插件,可以制作出滑块、开关按钮、进度条、向导步骤等多种效果。
47 5
|
2月前
|
JavaScript
js实现简洁实用的网页计算器功能源码
这是一款使用js实现简洁实用的网页计算器功能源码。可实现比较基本的加减乘除四则运算功能,界面简洁实用,是一款比较基本的js运算功能源码。该源码可兼容目前最新的各类主流浏览器。
35 2
|
2月前
|
JSON 移动开发 数据格式
html5+css3+js移动端带歌词音乐播放器代码
音乐播放器特效是一款html5+css3+js制作的手机移动端音乐播放器代码,带歌词显示。包括支持单曲循环,歌词显示,歌曲搜索,音量控制,列表循环等功能。利用json获取音乐歌单和歌词,基于html5 audio属性手机音乐播放器代码。
151 6
|
2月前
|
JavaScript
vue实现移动端6格验证码源码
这是一个vue移动端6格验证码特效,可支持自动填充,根据项目需求,可将发送验证码功能抽离成单独的组件使用。简单好用,欢迎下载!
38 0
|
3月前
|
人工智能 JavaScript 网络安全
ToB项目身份认证AD集成(三完):利用ldap.js实现与windows AD对接实现用户搜索、认证、密码修改等功能 - 以及针对中文转义问题的补丁方法
本文详细介绍了如何使用 `ldapjs` 库在 Node.js 中实现与 Windows AD 的交互,包括用户搜索、身份验证、密码修改和重置等功能。通过创建 `LdapService` 类,提供了与 AD 服务器通信的完整解决方案,同时解决了中文字段在 LDAP 操作中被转义的问题。
|
4月前
|
移动开发 前端开发 JavaScript
JS配合canvas实现贪吃蛇小游戏_升级_丝滑版本_支持PC端和移动端
本文介绍了一个使用JavaScript和HTML5 Canvas API实现的贪吃蛇游戏的升级版本,该版本支持PC端和移动端,提供了丝滑的转向效果,并允许玩家通过键盘或触摸屏控制蛇的移动。代码中包含了详细的注释,解释了游戏逻辑、食物生成、得分机制以及如何响应不同的输入设备。
99 1
JS配合canvas实现贪吃蛇小游戏_升级_丝滑版本_支持PC端和移动端
|
3月前
|
JavaScript 前端开发 API