您现在的位置是:网站首页> 编程资料编程资料
JavaScript实现移动端短信验证码流程介绍_javascript技巧_
2023-05-24
368人已围观
简介 JavaScript实现移动端短信验证码流程介绍_javascript技巧_
实战效果演示

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

代码部分
HTML
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时,自动发送短信验证请求.
到此这篇关于JavaScript实现移动端短信验证码流程介绍的文章就介绍到这了,更多相关JS短信验证码内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- Vue MVVM模型与data及methods属性超详细讲解_vue.js_
- JS面试之异步模拟超时重传机制详解_JavaScript_
- Vue computed计算属性详细讲解_vue.js_
- 解决router.beforeEach()动态加载路由出现死循环问题_vue.js_
- element ui中表单el-form的label如何设置宽度_vue.js_
- React 跨端动态化核心技术实例分析_React_
- Vue中router.beforeEach与beforeRouteEnter的区别及说明_vue.js_
- vue element插件this.$confirm用法及说明(取消也可以发请求)_vue.js_
- TypeScript类型any never void和unknown使用场景区别_js其它_
- Axios在vue项目中的封装步骤_vue.js_
