当前位置: 首页 > ai >正文

js实现生成随机验证码

需求说明

用户登录界面,需要先通过前端层的校验,才允许用户发送手机验证码进一层校验。本篇文章为如何实现前端验证码校验。

实现思路

本人实现的步骤是背景颜色加随机四位字母或数字验证码,其实就是给一个css样式,加一个背景颜色,字体加一个颜色,模仿成一张图片的样式。用户输入后,把用户输入的四位验证码与随机生成的验证码作比较。如果校验时区分大小写,就把用户输入的验证码全部转为大写或者小写后再进行比较。

主要代码实现

  1. 写一个随机生成四位验证码,包含大小写字母和数字;
  2. 监听验证码输入框,如果输入了4位,就把用户输入的验证码全部转为大写,或者全部转为小写(这里是全部转为了小写),以便实现不区分大小写的校验功能;
  3. 也可以不使用watch监听时间,而是在输入框上添加input事件或者change事件来判断用户输入的验证码是否正确。
  4. 比较生成的随机四位验证码与用户输入的是否一致,一致就把发送验证码的按钮取消禁用状态(也可以自己添加校验成功 / 失败的后续逻辑)。
methods: {
// 生成四位验证码generateCode() {const chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';let code = '';for (let i = 0; i < 4; i++) {const randomIndex = Math.floor(Math.random() * chars.length);code += chars.charAt(randomIndex);}this.randomCode = code},
}watch: {code(newVal) {if (newVal.length == 4 && newVal.toLowerCase() == this.randomCode.toLowerCase()) {this.sendbtnDisabled = false} else {this.sendbtnDisabled = true}}},

效果图

在这里插入图片描述

http://www.xdnf.cn/news/8944.html

相关文章:

  • Spring框架之AOP PointCut切入点底层实现原理
  • 【FFmpeg+SDL】播放音频时,声音正常但是有杂音问题(已解决)
  • 有铜半孔工艺的制造难点与工艺优化
  • 人工智能的能源困境:繁荣与危机并存的未来
  • 深入解析Spring Boot与Kafka集成:构建高效消息驱动应用
  • 塔能科技:化解工厂节能改造难题,开启能耗精准节能
  • 华为云Flexus+DeepSeek征文 | Dify-LLM平台一键部署教程及问题解决指南
  • Python常用高阶函数全面解析:通俗易懂的指南
  • 进行性核上性麻痹护理之道:助力患者舒适生活
  • 题目 3332: 蓝桥杯2025年第十六届省赛真题-最多次数
  • 快递实时查询API开发:物流轨迹地图集成教程
  • 遥感解译项目Land-Cover-Semantic-Segmentation-PyTorch之三制作训练数据
  • 从ETL到实时数据处理:数据流管理的演变与未来趋势
  • 谷歌Veo vs Sora:AI视频生成技术的巅峰对决
  • 5G技术赋能楼宇自控系统,数据传输与指令响应效率双提升
  • Spring Boot + OpenCSV 数据清洗实战:CSV 结构化处理与可视化
  • MQTT-Vue整合
  • Linux_编辑器Vim基本使用
  • 快速解决azure aks aad身份和权限问题
  • Parasoft C++Test软件单元测试_实例讲解(局部静态变量的处理)
  • Ubuntu从0到1搭建监控平台:本地部署到公网访问实战教程Cpolar穿透与Docker部署全过程
  • 云原生微服务devops项目管理英文表述详解
  • 君正Ingenic webRTC P2P库libyangpeerconnection7编程指南
  • 鸿蒙OSUniApp 开发的多图浏览器组件#三方框架 #Uniapp
  • 面试刷题4:java(核心+acm模式)
  • Mac安装配置InfluxDB,InfluxDB快速入门,Java集成InfluxDB
  • 华清远见亮相第63届高博会,展示AI/嵌入式/物联网/具身智能全栈教学解决方案
  • Java中的设计模式:单例模式的深入探讨
  • 【生产实践】华为存储XSG1在RHEL 7.x/8.x上的多路径配置操作手册(生产环境)
  • Taro on Harmony C-API 版本正式开源