Javascript的form表单校验输入框
以下是HTML代码:
<form name="myForm" onsubmit="return validateForm()"><label for="name">姓名:</label><input type="text" id="name" name="name"><br><label for="email">电子邮件:</label><input type="email" id="email" name="email"><br><label for="age">年龄:</label><input type="number" id="age" name="age"><br><label for="phone">电话号码:</label><input type="tel" id="phone" name="phone"><br><label for="address">地址:</label><input type="text" id="address" name="address"><br><label for="username">用户名:</label><input type="text" id="username" name="username"><br><input type="submit" value="提交"></form>
以下是js实现:
function validateForm() {var name = document.forms["myForm"]["name"].value;var email = document.forms["myForm"]["email"].value;var age = document.forms["myForm"]["age"].value;var phone = document.forms["myForm"]["phone"].value;var address = document.forms["myForm"]["address"].value;var username = document.forms["myForm"]["username"].value;if (name == "") {alert("请填写姓名");return false;}if (email == "") {alert("请填写电子邮件");return false;} else {var emailPattern = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;if (!emailPattern.test(email)) {alert("请输入有效的电子邮件地址");return false;}}if (age == "") {alert("请填写年龄");return false;} else {if (isNaN(age) || age < 0 || age > 120) {alert("请输入有效的年龄");return false;}}if (phone == "") {alert("请填写电话号码");return false;} else {var phonePattern = /^\d{11}$/;if (!phonePattern.test(phone)) {alert("请输入有效的电话号码(11位数字)");return false;}}if (address == "") {alert("请填写地址");return false;}if (username == "") {alert("请填写用户名");return false;}return true;}
定义了一个名为
validateForm的JavaScript函数,该函数用于验证表单数据。在函数中,首先获取每个输入框的值,然后逐一进行验证。对于每个输入框,我们使用条件语句来检查其值是否满足特定要求,并在不符合要求时显示警告框并返回false以阻止表单提交。例如,如果姓名字段为空,则显示警告框并返回false。同样地,我们使用正则表达式来验证电子邮件和电话号码的格式,使用比较运算符来验证年龄的范围。
在HTML部分,我们将每个输入框与相应的标签进行关联,并在表单元素上添加了
onsubmit事件来调用validateForm函数。如果所有输入框的值都通过验证,将允许表单提交;否则,将阻止表单提交。
相关文章:
Javascript的form表单校验输入框
以下是HTML代码: <form name"myForm" onsubmit"return validateForm()"><label for"name">姓名:</label><input type"text" id"name" name"name"><br><l…...
大数据-之LibrA数据库系统告警处理(ALM-37003 GTM主备不同步或者GTM主备断连)
告警解释 当GTM主实例与GTM备实例连接异常或者GTM主实例未处于同步状态时,产生该告警。 告警属性 告警ID 告警级别 可自动清除 37003 严重 是 告警参数 参数名称 参数含义 ServiceName 产生告警的服务名称 RoleName 产生告警的角色名称 HostName 产…...
python每日一题——4移动0
题目 给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 请注意 ,必须在不复制数组的情况下原地对数组进行操作。 示例 1: 输入: nums [0,1,0,3,12] 输出: [1,3,12,0,0] 示例 2: 输入: nums [0]…...
CAN实验
CAN 寄存器 HAL库函数 代码 #include "./BSP/CAN/can.h"CAN_HandleTypeDef g_can1_handle; CAN_TxHeaderTypeDef g_can1_txheader; CAN_RxHeaderTypeDef g_can1_rxheader;/* STM32F103 TS1 8 TS2 7 BRP 3 波特率:36000 / [(9 8 1) * 4] 500Kbps …...
(一)pytest自动化测试框架之生成测试报告(mac系统)
前言 我们可以通过pytest-html插件来生成测试报告,但是pytest-html插件生成的测试报告不够美观,逼格也不够高,通过allure生成的测试报告是比较美观的,花里胡哨的,能够提升一个level。 allure官网: Allure…...
微服务实战系列之Nginx
前言 Nginx?写了那么多文章,为什么今天才轮到它的表演?那是因为它实在太重要了,值得大书特书,特别对待。 当我们遇到单点瓶颈,第一个idea是?Nginx; 当我们需要反向代理,…...
使用rsync从OpenShift的pod复制文件
环境 Red Hat Enterprise Linux release 8.6 (Ootpa)OCP 4.12.22 准备 安装rsync: yum install rsync 查看pod: [rootapi.kai1123.cp.fyre.ibm.com ~]# oc get pod -n cpd-instance | grep dmc ...... ibm-dmc-1700727413211000-monitor-0 …...
解决Activiti5.22流程图部署在Windows上正常,但在linux上部署后出现中文变方块的问题
总结/朱季谦 楼主最近在做公司的工作流平台,发现一个很无语的事情,Activiti5.22的流程图在Windows环境上部署,是可以正常查看的,但发布到公司的Linux服务器上后,在上面进行流程图在线部署时,发现中文都变成…...
EMG肌肉电信号处理合集(三)
本文主要展示常见的肌电信号预处理的实现,开发环境为matlab。 目录 1 肌电信号低通,高通,带通滤波 2 去除DC 0阶偏置,1阶偏置 3 全波整流 4 信号降采样 5 linear envolope / butterworth 低通滤波器 1 肌电信号低通…...
GitHub桌面版
GitHub桌面版 一、GitHub 桌面版二、clone 仓库三、更新仓库 一、GitHub 桌面版 二、clone 仓库 三、更新仓库...
【广州华锐互动】昆虫3D虚拟动态展示:探索神奇的微观世界
在这个充满科技魅力的时代,我们可以通过各种方式去了解和探索自然界的奥秘。而昆虫作为地球上最为丰富多样的生物群体之一,其独特的生活习性和形态特征一直吸引着人们的目光。 由广州华锐互动开发的昆虫3D虚拟动态展示系统,成为了一种全新的科…...
《QT从基础到进阶·三十六》QWidget实现收缩栏的效果
功能: 1、可以在收缩栏插件中添加界面 2、可以把界面展开或收缩 3、可以用鼠标拖动界面改变界面的排放顺序 源码放在最下方 1、可以在收缩栏插件中添加界面 virtual void addWidget(QWidget* widget, const QString& label, const QIcon& icon QIcon())…...
运行软件报错找不到vcruntime140.dll无法继续执行代码怎么办-6个解决方法
vcruntime140.dll是一个由Microsoft Visual C提供的运行时库文件,它为许多Microsoft Visual Studio开发的应用程序提供了必要的支持。这个文件对于许多Windows应用程序的正常运行至关重要。然而,有时会出现vcruntime140.dll缺失的问题,导致应…...
从Discord的做法中学习 — 使用Golang进行请求合并
正如你可能之前看到的,Discord去年发布了一篇有价值的文章,讨论了他们成功存储了数万亿条消息。虽然有很多关于这篇文章的YouTube视频和文章,但我认为这篇文章中一个名为“数据服务为数据服务”的部分没有得到足够的关注。在这篇文章中&#…...
【教3妹学编程-算法题】统计和小于目标的下标对数目
2哥 : 3妹,OpenAI的宫斗剧迎来了大结局!OpenAI宣布阿尔特曼复职CEO,董事会重组 3妹:啊?到底谁才是幕后操纵者啊,有咩有揪出来 2哥 : 也不是很清楚,据说在被开除的几周前,前CEO曾谴责…...
OSG粒子系统与阴影-雾效模拟(1)
虚拟现实中有很多效果,如雨效、雪效、雾效等,这些都可以通过粒子系统来实现。一个真实的粒子系统的模式能使三维场景达到更好的效果。 本章对OSG粒子系统的使用以及生成自定义粒子系统的方法进行了详细介绍最后还附带说明了阴影的使用方法。在实时的场景…...
Windows power shell for循环
有时候需要重复执行某个shell命令 for($i1;$i -lt 10;$i$i1){echo $i}如果是cmd for /l %i in (1,1,5) do echo %i...
GIT实践与常用命令---回退
实践场景 场景1 回退提交 在日常工作中,我们可能会和多个同事在同一个分支进行开发,有时候我们可能会出现一些错误提交,这些错误提交如果想撤销,可以有两种解决办法:回退( reset )、反做(revert) keywords:reset、rev…...
Python-Django的“日志功能-日志模块(logging模块)-日志输出”的功能详解
01-综述 可以使用Python内置的logging模块来实现Django项目的日志记录。 所以与其说这篇文章在讲Django的“日志功能-日志模块-日志输出”,不如说是在讲Pthon的“日志功能-日志模块-日志输出”,即Python的logging模块。 下面用一个实例来进行讲解。 …...
C现代方法(第23章)笔记——库对数值和字符数据的支持
文章目录 第23章 库对数值和字符数据的支持23.1 <float.h>: 浮点类型的特性23.2 <limits.h>: 整数类型的大小23.3 <math.h>: 数学计算(C89)23.3.1 错误23.3.2 三角函数23.3.3 双曲函数23.3.4 指数函数和对数函数23.3.5 幂函数23.3.6 就近舍入、绝对值函数和取…...
别再死记硬背KP-ABE和CP-ABE了!用一张图+一个Python小例子帮你彻底搞懂访问树
用Python实战图解KP-ABE与CP-ABE:从访问树到属性解密的本质差异 在数据安全领域,基于属性的加密(Attribute-Based Encryption, ABE)技术正逐渐成为细粒度访问控制的主流方案。但许多初学者面对KP-ABE(Key-Policy ABE&a…...
FPGA开发者必看:Xilinx SRIO IP核的AXI4-Stream接口实战指南(含HELLO包时序详解)
FPGA开发者实战指南:Xilinx SRIO IP核AXI4-Stream接口深度解析 在高速嵌入式系统设计中,芯片间通信的带宽和延迟往往是性能瓶颈的关键所在。Xilinx的Serial RapidIO(SRIO)IP核为解决这一挑战提供了高效解决方案,尤其适…...
从手机芯片到自动驾驶:算力单位TOPS/MACs/FLOPS是如何影响你每天使用的技术的?
从手机芯片到自动驾驶:算力单位如何塑造你的数字生活? 清晨的闹钟响起时,你拿起手机用面部识别解锁,语音助手根据指令调整空调温度,通勤路上汽车自动保持车道——这些场景背后都有一场看不见的算力博弈。当我们谈论TO…...
Obsidian中完美播放B站视频的终极解决方案:Media Extended B站插件完整指南
Obsidian中完美播放B站视频的终极解决方案:Media Extended B站插件完整指南 【免费下载链接】mx-bili-plugin 项目地址: https://gitcode.com/gh_mirrors/mx/mx-bili-plugin 你是否厌倦了在Obsidian笔记中只能粘贴B站链接而无法直接播放视频的困扰ÿ…...
Klipper固件深度解析:3大突破性功能如何解决3D打印核心痛点
Klipper固件深度解析:3大突破性功能如何解决3D打印核心痛点 【免费下载链接】klipper Klipper is a 3d-printer firmware 项目地址: https://gitcode.com/GitHub_Trending/kl/klipper 在3D打印领域,精度不足、振动干扰和配置复杂是长期困扰用户的…...
大模型的探索与实践-课程笔记(四):Agent与Multi-Agent
Take-away MessagesAgent智能体 让大模型能够调用工具 规划、记忆、行动 Manus / OpenManus 在本地部署OpenManusMulti-Agent 任务分解、任务联动 Coze 利用Coze构建智能体1.1 从大模型(LLM)到智能体(Agent)1. 概念演进࿱…...
FPGA以太网调试避坑指南:解决AC620开发板LWIP项目中的‘timestamp不匹配’与网口驱动问题
FPGA以太网开发实战:从AC620开发板到LWIP协议栈的深度调试指南 当FPGA工程师第一次尝试在NIOS II软核上实现以太网功能时,往往会遇到各种意想不到的"坑"。本文将以小梅哥AC620开发板为硬件平台,深入剖析LWIP协议栈在FPGA上的实现细…...
机械识图:剖视图
视图主要用于表达机件的外部形状和结构,当机件的内部形状和结构(简称为内形)比较复杂时,若采用视图表示,在某些视图中就会出现较多的虚线,既不便于读图和标注尺寸,图面也不清晰。剖视图的形成 假…...
Visual C++运行库终极解决方案:告别繁琐安装的一站式指南
Visual C运行库终极解决方案:告别繁琐安装的一站式指南 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 您是否曾经因为"缺少VC运行库"的错…...
经验分享:国产嵌入式实时操作系统reworks.elf 镜像固化与启动(飞腾E2000Q/龙芯3A3000/Zynq、复旦微7045平台通用)
📖 封面摘要 本文详细整理龙芯(LS2K/3A/2K派)、飞腾E2000、Zynq/复旦微7045三大主流嵌入式平台,启动国产嵌入式实时操作系统reworks.elf镜像的网络引导、本地固化、自动启动完整流程,包含规范命令、操作步骤、速查表、问题排查,命令可直接复制用于开发调试,适合嵌入式…...
