原生JS写表单验证提交功能
先上效果图:

表单的基础内容就是昵称判断、手机号判断、邮箱判断、身份证号码判断,这里是用到正则验证检验格式。
页面的表单写法就是一个form的提交。输入框用input来实现,输入内容用value来获取。每个输入框用唯一的ID名字来标记:
<body>
<div class="content">
<div class="title">用户注册</div>
<form onsubmit="return false">
<div><label><span>*</span>昵称:</label><input onfocus="clearErr()" id="name" type="text" placeholder="只能包含中文、英文、数字和下划线"></div>
<div><label><span>*</span>手机:</label><input onfocus="clearErr()" id="phone" type="text" placeholder=""></div>
<div><label>邮箱:</label><input onfocus="clearErr()" id="email" type="text"></div>
<div><label>身份证号:</label><input onfocus="clearErr()" id="cardCode" type="text"></div>
<div><label>毕业学校:</label><input onfocus="clearErr()" id="school" type="text"></div>
<div><button id="registerBtn" type="submit">注册</button></div>
<div id="errContent"></div>
</form>
</div>
</body>
通过JS来实现输入验证,和正则验证:
<script>
window.onload = function(){
var oRegisterBtn = document.getElementById('registerBtn');
var oName = document.getElementById('name');
var oPhone = document.getElementById('phone');
var oEmail = document.getElementById('email');
var oCardCode = document.getElementById('cardCode');
var oschool = document.getElementById('school');
var oErrContent = document.getElementById('errContent');
oRegisterBtn.onclick = function(){
var doRegister = true;
var errStr = "";
if(!oName.value){
errStr += "用户名不能为空</br>";
doRegister = false;
}else if(/[^\u4e00-\u9fa5\w]/.test(oName.value)){
errStr += "用户名格式不对" +"</br>";
doRegister = false;
}
if(!oPhone.value){
errStr += "手机号不能为空</br>";
doRegister = false;
}else if(!/^1[3|4|5|8][0-9]\d{4,8}$/.test(oPhone.value)){
errStr += "手机号格式不对</br>";
doRegister = false;
}
if(oEmail.value && !/^\w+@[a-z0-9]+(\.[a-z]+){1,3}$/.test(oEmail.value)){
errStr += "邮箱格式不对</br>";
doRegister = false;
}
if(oCardCode.value && !/[1-9]\d{14}|[1-9]\d{17}|[1-9]\d{16}x/.test(oCardCode.value)){
errStr += "身份证号式不对</br>";
doRegister = false;
}
if(doRegister){
//此处写相应的ajax提交
alert("您的资料已提交...");
}else{
oErrContent.innerHTML = errStr;
}
}
}
function clearErr(){
document.getElementById('errContent').innerHTML = "";
}
</script>
样式内容也简单贴上吧:
<style>
*{
margin:0;
padding:0;
}
.content{
width:800px;
margin:50px auto;
}
.title{
font-size:18px;
font-weight:bold;
padding-left:340px;
margin-bottom:30px;
}
input{
border:1px solid #a9a9a9;
height:34px;
line-height:34px;
width:550px;
margin-bottom:20px;
padding-left:5px;
}
label{
width:120px;
text-align:right;
display:inline-block;
}
#registerBtn{
background:#3498db;
color:#fff;
font-size:14px;
text-align:center;
width:100px;
line-height:34px;
border:none 0;
cursor:pointer;
margin:20px 20px 0 0;
margin-left:120px;
}
label span{
color:red;
}
#errContent{
padding:20px 0 0 30px;
text-align:center;
}
</style>
表单验证用到的地方多,也有很多人写过,所以我这里只是用更简洁的方法来实现。同理可以推陈出新很多内容
原生JS写表单验证提交功能的更多相关文章
- 原生js制作表单验证,基本的表单验证方法
表单验证是web前端最常见的功能之一,也属于前端开发的基本功.自己完成一个表单验证的开发,也有助于加深对字符串处理和正则表达式的理解. 基本的表单验证包括如:字母验证.数字验证.字母和数字验证.汉字验 ...
- 原生js的表单验证
最近在学原生的js,把一些练手的代码往博客放一放,权当积累经验,若有错漏,或是觉得浅显,大家不要见怪. 这是一个原生js编写的简单的表单验证: <!DOCTYPE html><htm ...
- 表单验证提交——submit与button
之前做东西接触过表单验证提交,但是都是为了完成工作,做完就做完了,没有注过表单验证提交有几种方法,各方法都有啥区别.今天瞎折腾了一下,对他们研究了一下,如下是我个人的理解: submit: 从字面上看 ...
- 第一百五十四节,封装库--JavaScript,表单验证--提交验证
封装库--JavaScript,表单验证--提交验证 将表单的所有必填项,做一个判断函数,填写正确时返回布尔值 最后在提交时,判断每一项是否正确,全部正确才可以 提交 html <div id= ...
- ★★★【卡法 常用js库】: js汇合 表单验证 cookie设置 日期格式 电话手机号码 email 整数 小数 金额 检查参数长度
[卡法 常用js库]: js汇合 表单验证 cookie设置 日期格式 电话手机号码 email 整数 小数 金额 检查参数长度 // +---------------------- ...
- 表单提交学习笔记(二)—使用jquery.validate.js进行表单验证
一.官网下载地址:http://plugins.jquery.com/validate/ 二.用法 1.在页面上进行引用 <script src="~/scripts/jquery-1 ...
- js基础-表单验证和提交
基础知识: 原始提交如下: <form action="/login" method="post" id="form1"> &l ...
- JS通用表单验证函数,基于javascript正则表达式
表单的验证在实际的开发当中是件很烦琐又无趣的事情今天在做一个小项目的时候,需要JS验证,寻找到一个比较好的东西 地址如下: http://blog.csdn.net/goodfunman/archiv ...
- JS简单表单验证
这里我是写了一个简单的注册表单验证功能,亲测有效,一起来看看吧! 首先我的HTML代码是这样的: class大家可以忽略一下,这里我项目使用的是bootstrap的样式. 输入用户名和密码用的是正则表 ...
随机推荐
- python邮箱发送
普通发送邮件 使用email模块和stmplib模块,内容比较固定,配好了即可实现,代码如下 一.普通邮箱发送 # -*- coding:utf-8-*- import smtplib from em ...
- Java8新特性——Optional
前言 在开发中,我们常常需要对一个引用进行判空以防止空指针异常的出现.Java8引入了Optional类,为的就是优雅地处理判空等问题.现在也有很多类库在使用Optional封装返回值,比如Sprin ...
- mongodb插入性能
转自 https://blog.csdn.net/asdfsadfasdfsa/article/details/60872180 MongoDB与MySQL的插入.查询性能测试 7.1 平均 ...
- SQL的四种连接(内连接,外连接)
一,内连接(inner join) 内连接(INNER JOIN):分显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行.(所谓的连接表就是数据库在做查询形成的中间表). 1.隐式的内连接 没 ...
- MySQL之可视化软件
MySQL可视化客户端 多款可视化界面,总有一款适合你 个人推荐使用MySQL官方提供的可视化工具. 下载链接 使用方法链接
- Spring学习(二)
IoC 1.Inverse of Control ,控制反转(控制权的翻转) 2.控制:对对象的创建.对对象的属性赋值等一系列操作本来应该是我们做的事情 Java Application : Date ...
- 吴裕雄 Bootstrap 前端框架开发——Bootstrap 排版:使段落突出显示
<!DOCTYPE html> <html> <head> <title>菜鸟教程(runoob.com)</title> <meta ...
- 使用mvn deploy命令将本地jar包上传到maven私服
记录一下,以后少走弯路 前提:已经搭建好nexus maven私服,地址192.168.110.240:9091 在maven的setting.xml中找到<mirrors></mi ...
- SpringBoot图文教程3—「‘初恋’情结」集成Jsp
有天上飞的概念,就要有落地的实现 概念+代码实现是本文的特点,教程将涵盖完整的图文教程,代码案例 文章结尾配套自测面试题,学完技术自我测试更扎实 概念十遍不如代码一遍,朋友,希望你把文中所有的代码案例 ...
- Django 学习之cookie与session
一.cookie和session的介绍 cookie不属于http协议范围,由于http协议无法保持状态,但实际情况,我们却又需要“保持状态”,因此cookie就是在这样一个场景下诞生. cookie ...