JavaScript的综合案例

案例要求:

实现一个表单验证

1.当输入框失去焦点时,验证输入的内容是否符合要求

2.当点击注册按钮时,判断所有输入框的内容是否都符合要求,如果不符合要求阻止表单提交

简单的页面实现

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>欢迎注册</title>
</head>
<body><h1>欢迎注册</h1><form action="#" id="register"><table><tr><td>用户名</td><td><input type="text" name="username" id="username" ><!-- 先设置为隐藏格式 --><span id="uwername_err" style="display: none;" >用户名不符合规则</span></td></tr><tr><td>密码</td><td><input type="password"  name="password" id="password"><span id="password_err" style="display: none;" >密码不符合规则</span></td></tr><tr><td>电话</td><td><input type="text" name="tel" id="tel"><span id="tel_err" style="display: none;" >电话不符合规则</span></td></tr></table><input type="button" value="提交"></form></body>
</html>

 

1.当输入框失去焦点时,验证输入的内容是否符合要求

我们先设置用户名的事件,当鼠标离焦该元素时,触发函数

<tr><td>用户名</td><td><!-- //给用户框元素绑定一个离焦事件,当鼠标离开该元素就触发函数 --><input type="text" name="username" id="username" onblur="checkUsername()"><!-- 先设置为隐藏格式 --><span id="uwername_err" style="display: none;" >用户名不符合规则</span></td></tr>

 checkUsername函数的实现

 <script>function checkUsername(){//获取用户框输入的值let usernameValue= document.getElementById("username").value;//创建正则对象// let regex=new RegExp("^\\w{6,10}$");let regex=/^\w{6,10}$/;//判断输入的值是否符合正则if(regex.test(usernameValue)){
//重现设置为隐藏document.getElementById("uwername_err").style.display="none";return true;}else{//不满足,把用户名的span标签显示出来document.getElementById("uwername_err").style.display="block";document.getElementById("uwername_err").style.color="red";//阻止表单提交return false;}}</script>

结果:

设置密码的绑定事件

 <tr><td>密码</td><td><input type="password"  name="password" id="password" onblur="checkPassword()"><span id="password_err" style="display: none;" >密码不符合规则</span></td></tr>

 checkPassword函数

   <script>function checkPassword(){//获取密码框输入的值let passwordValue=document.getElementById("password").value;//创建正则对象let regex=/^.{6,12}$/;//判断是否满足if(regex.test(passwordValue)){//满足,把密码的span标签内容隐藏document.getElementById("password_err").style.display="none";//提交表单return true;}else{//不满足document.getElementById("password_err").style.display="block";document.getElementById("password_err").style.color="red";return false;}}
</script>

 设置电话的绑定事件

<tr><td>电话</td><td><input type="text" name="tel" id="tel" onblur="checkTel()"><span id="tel_err" style="display: none;" >电话不符合规则</span></td></tr>

checkTel函数

 <script>function checkTel(){//获取电话框输入的值let telValue=document.getElementById("tel").value;//创建正则对象let regex=/^1[3-9]\d{9}$/;if(regex.test(telValue)){document.getElementById("tel_err").style.display="none";return true;}else{//不满足document.getElementById("tel_err").style.display="block";document.getElementById("tel_err").style.color="red";return false;}}
</script> 

2.当点击注册按钮时,判断所有输入框的内容是否都符合要求,如果不符合要求阻止表单提交 

我们现在实现的功能有一个框不符合规则也可以提交数据成功 

<script>
//给form表单绑定提交事件document.getElementById("register").onsubmit=function(){//三个框只要有一个非法就组织表单提交return checkPassword()&&checkTel()&&checkUsername();}
</script>

说明:onsubmit的匿名函数返回false就不提交数据

结果:有一个不符合,就不提交数据

说明:全部符合,才提交数据

浏览器debug

1.在页面打开控制台

2.打开源代码 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/12218.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在阿里云服务器上安装MySQL

目录 一、先卸载不需要的环境 1.关闭MySQL服务 2.查看安装包以及卸载安装包 3.依次卸载所有包 4. 获取mysql官⽅yum源 二、安装&#xff08;密钥过期解决方法&#xff09; 三、启动并进入 关于MySQL MySQL是一个广泛使用的开源关系型数据库管理系统&#xff08;RDBMS&…

【深度学习中的“冻结”含义】

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、冻结操作二、实际使用三 、案例训练代码... 总结 前言 在深度学习领域&#xff0c;“冻结”的含义通常指的是在训练过程中保持网络模型中的某一层或多层的…

Linux中如何配置虚拟机网络(NAT方法)

首先我们要在Linux中找到配置文件的路径/etc/sysconfig/network-scripts/&#xff0c;然后找到配置文件的名称ifcfg-xxx&#xff08;如&#xff1a;ifcfg-ens33&#xff09;&#xff0c;然后打开这个文件内 容如下&#xff1a; TYPEEthernet # 指定网卡类型是以太网 BOOTPROT…

解决qt5.12.12编译源码没有libqxcb的问题

最近要研究一下qt源码,因为设计到要修改源码,所以需要编译源码并替换修改的库文件运行验证。 我这里使用的是qt5.12.12版本,去官网上下载对应版本的安装包,安装时勾选上源码即可。 后面编译完发现,plugins/platforms/目录下没有生成库文件libqxcb.so,造成了一点麻烦。 设置 e…

【平衡二叉树】AVL树(双旋)

&#x1f389;博主首页&#xff1a; 有趣的中国人 &#x1f389;专栏首页&#xff1a; C进阶 &#x1f389;其它专栏&#xff1a; C初阶 | Linux | 初阶数据结构 小伙伴们大家好&#xff0c;本片文章将会讲解AVL树的左双选和右双旋的相关内容。 如果看到最后您觉得这篇文章写…

C++基础语法之数组

一、一维数组 在C中&#xff0c;一维数组是一系列具有相同数据类型的元素的集合。它们在内存中是连续存储的&#xff0c;可以通过索引访问每个元素。 一维数组的声明形式如下&#xff1a; 数据类型 数组名[常量表达式] 例如&#xff1a; // 声明一个能存储10个整数的数组 in…

【AI学习】对指令微调(instruction tuning)的理解

前面对微调&#xff08;Fine-tuning&#xff09;的学习中&#xff0c;提到指令微调。当时&#xff0c;不清楚何为指令微调&#xff0c;也一直没来得及仔细学习。 什么是指令微调&#xff1f;LLM经过预训练后&#xff0c;通过指令微调提升模型的指令遵循能力。所谓指令&#xf…

从零开始精通RTSP之认证

概述 在多媒体流传输方向&#xff0c;RTSP凭借其对实时性、可控制性的良好支持&#xff0c;成为视频监控、在线直播等领域不可或缺的协议之一。然而&#xff0c;安全是任何网络通信的核心&#xff0c;尤其是在涉及敏感内容的实时流传输中。另外&#xff0c;RTSP认证不仅是技术上…

Flutter 中的 AnimatedIcon 小部件:全面指南

Flutter 中的 AnimatedIcon 小部件&#xff1a;全面指南 AnimatedIcon是Flutter Material组件库中的一个独特动画组件&#xff0c;它允许开发者在两个图标之间进行平滑的过渡动画。这使得它非常适合用于表示应用程序的状态变化&#xff0c;如菜单打开/关闭、搜索打开/关闭等。…

java动态多态性

在Java中&#xff0c;动态多态性是指同一个方法调用可以在运行时根据对象的实际类型来执行不同的行为。这是通过Java的方法重写&#xff08;Override&#xff09;和继承机制来实现的。 动态多态性的实现方式&#xff1a; 方法重写&#xff08;Override&#xff09;&#xff1a…

box-shadow和filter: drop-shadow的异同,及使用canvas绘制椭圆

一、box-shadow 和 filter: drop-shadow的异同&#xff1a; filter: drop-shadow 和 box-shadow 都可以用于创建阴影效果&#xff0c;但它们之间有一些重要的区别&#xff1a; 1、适用对象&#xff1a; 1、filter: drop-shadow* 适用于元素的整个内容区域&#xff0c;包括内容…

车载GPT爆红前夜:一场巨头竞逐的游戏

在基于GPT-3.5的ChatGPT问世之前&#xff0c;OpenAI作为深度学习领域并不大为人所看好的技术分支玩家&#xff0c;已经在GPT这个赛道默默耕耘了七八年的时间。 好几年的时间里&#xff0c;GPT始终没有跨越从“不能用”到“能用”的奇点。转折点发生在2020年6月份发布的GPT-3&a…

【STM32】状态机实现定时器按键消抖,处理单击、双击、三击、长按事件

目录 一、简单介绍 二、模块与接线 三、cubemx配置 四、驱动编写 状态图 按键类型定义 参数初始化/复位 按键扫描 串口重定向 主函数 五、效果展示 六、驱动附录 key.c key.h 一、简单介绍 众所周知&#xff0c;普通的机械按键会产生抖动&#xff0c;可以采取硬件…

注意力机制篇 | YOLOv8改进之在C2f模块引入反向残差注意力模块iRMB | CVPR 2023

前言:Hello大家好,我是小哥谈。反向残差注意力模块iRMB是一种用于图像分类和目标检测的深度学习模块。它结合了反向残差和注意力机制的优点,能够有效地提高模型的性能。在iRMB中,反向残差指的是将原始的残差块进行反转,即将卷积操作和批量归一化操作放在了后面。这样做的好…

软件工程期末复习(6)需求分析的任务

需求分析 需求分析的任务 “建造一个软件系统的最困难的部分是决定要建造什么……没有别的工作在做错时会如此影响最终系统&#xff0c;没有别的工作比以后矫正更困难。” —— Fred Brooks 需求难以建立的原因&#x…

.net iText7 导出网页pdf 文件流

一. Install-Package itext7 二.构建字节流 using System.IO; using iText.Html2pdf; using iText.Kernel.Pdf; using iText.Layout; using iText.Layout.Element;public byte[] ConvertUrlToPdf(string url) {// 创建一个内存流用于存储PDF文件MemoryStream pdfStream new…

矩阵相关运算1

矩阵运算是线性代数中的一个核心部分&#xff0c;它包含了许多不同类型的操作&#xff0c;可以应用于各种科学和工程问题中。 矩阵加法和减法 矩阵加法和减法需要两个矩阵具有相同的维度。操作是逐元素进行的&#xff1a; CAB or CA−B其中 A,B 和 C 是矩阵&#xff0c;且 C…

unity删除文件到回收站

unity editor下删除文件及文件夹到回收站: unity删除文件到回收站 if (AssetDatabase.MoveAssetToTrash(removeFolder)) {AssetDatabase.MoveAssetToTrash(removeFolder ".meta"); }removeFolder“Asset/Test.txt”; 使用下面的删除了无法恢复 if (FileUtil.Delet…

7nm项目之模块实现——02 Placeopt分析

一、Log需要看什么 1.log最后的error 注意&#xff1a;warnning暂时可以不用过于关注&#xff0c;如果特别的warning出现问题&#xff0c;在其他方面也会体现 2.run time 在大型项目实际开发中&#xff0c;周期一般较长&#xff0c;可能几天过这几周&#xff0c;所以这就需要…

leetcode 2321.拼接数组的最大分数

思路&#xff1a;dp 这道题其实确实是有点难想&#xff0c;而且是很难联想到做法的那种。&#xff08;需要有一定的经验才行&#xff09;但是如果说有了思路&#xff0c;其实就很简单了。 我们可以在草纸上画上一下。比如&#xff0c;我们以第一个数组为基准&#xff0c;我们…