表单input中录入资料的检查方法及示例
本文内容
表单录入信息的检查原则
常见检查的三种方法
示例
 输入框有字符长度的限制
 输入框有输入字符个数范围的限制
知识补给--检查方式的介绍
 输入框只可(或不可)输入数字
 输入框只可(或不可)输入英文
 输入框只可(或不可)输入英文与数字
 输入框只可(或不可)输入中文
 输入框只可输入特定的文字、数字或符号
 综合示例(验证台湾居民身份证)
附录(常用到正则表达式的符号与说明)
表单录入信息的检查原则
尽可能使用选择的方式来减少浏览者用键盘输入资料的操作,如此不仅让浏览者更简单方便地输入资料,也降低输入错误的几率与后续的检查工作。
常见检查的三种方法
 实时检查:就是当在栏位中输入完资料(通常是失去焦点时)就立即进行检查,若不正确则将光标(也就是焦点,Input Focus)重新移回次栏位上,要求重新输入;
 集中检查:当浏览者单击提交资料(或确定)按钮后,由onSubmit调用处理函数来对所有输入的资料进行检查,若发现不正确或资料错误就显示信息(如对话框)告诉浏览者,并要求重新输入;
 后台检查:在网页中完全不检查各栏位资料的正确性,将所有浏览者输入的资料送到后台去检查(通常是由ASP或CGI程序进行检查)。但是!若输入的资料有问题则较难立刻反馈给浏览者,也为后台服务器增加负担。
摆完理论,咱们总得来点实例吧。(对,实例和示例确实有点难于区分!)
- 输入框有字符长度的限制具体例子,比如手机号、邮编号等。 
功能描述:如手机号栏位必须输入11位数字,且不得超过此长度,同时输入不满11位的出现弹框提示!
实现代码
| <script>     function checkInput(inputL, max, it) {         if (inputL == "")return; //此语句允许该输入框为空,若想要把该输入框作为必填,则应该删除此语句; 
 if (inputL != max) { //此处的判断条件也可写成'inputL<max'             alert("请输入有效的手机号"); it.focus(); //将焦点返回到此输入框         }     } </script> <label>手机号<input type="tel" onblur="checkInput(this.value.length,11,this)" maxlength="11"> </label> | 
网页效果

 无错误弹窗提示
无错误弹窗提示
- 输入框有输入字符个数范围的限制如身高至少是2位,姓名至少是2位; 
功能描述:若输入的字符数不符合要求,则会跳出弹窗提示!
实现代码
| <script> if (inputL < min) {     //输入的字符串长度必须大于2 <label>身高 <input type="text" onblur="checkInput(this.value.length,2,this)" maxlength="3">cm </label> | 
网页效果

 无错误弹窗提示
无错误弹窗提示
 无错误弹窗提示
无错误弹窗提示
注:此方法是通过限制(value.length)输入的数字个数(默认用户很配合的输入数字),来实现一定范围的约束。那如果要真正实现数值范围的限制要怎么做呢?
我们可以通过input[type="number"]的min和max属性来实现真正地数值范围约束!
实现代码
|  | 
网页效果


知识补给
					
- 以下几个示例涉及到JavaScript Regex
- 检查方式
输入资料的检查方式,一般推荐实时检查而不建议到最后才检查(如单击onsubmit后才检查)。要实现实时检查一般推荐使用onkeyup。不用onblur和onchange的原因在于,这两者必须等到该栏位输入完成后(例如失去焦点或按下回车键)才能调用处理函数来检查。而onkeyup则是每按下一个键松开后就会进行检查(就算不合法还是会显示在输入框内,然后再删除)。打个比方,在输入框按下一个不允许的按键(如只可输入数字,但浏览者却输入了英文)就立刻删除它。
补充:onkeydown与onkeypress的检查方法,并不适合用于检查!
- 优点
实现实时检查,让浏览者知道哪些可以输入哪些不行,更重要的是,这样的输入资料就不会有错误,甚至之后也不必进行检查,可算是最佳的设计方式!
- 原理
输入框限对输入内容的控制是通过replace(searchvalue,newvalue)的两个参数来实现。定义searchvalue实现对输入内容的设置,然后通过定义newvalue设置替换内容。
具体设置:

			
- 警告!
 
当在<input>标签中使用onkeyup事件来过滤与检查输入的字符时,就不可以再设置onchange事件处理了,否则可能无法起作用。若需要的话,使用onblur一般是没有问题。
- 输入框只可(或不可)输入数字
功能描述:输入不合要求的字符立即自动回删!
功能实现关键语句
| 
  | 
实现代码
| <form method="get" action=""> | 
注:其中replace的用作替换的字符为空,表示只是回删不符合要求的字符,然后自动填上这个空字符。
- 输入框只可(或不可)输入英文
功能描述:输入不合要求的字符立即自动回删!
功能实现关键语句
| //只可输入英文字与空格,其他数字、符号、汉字都不行 
 //只可输入英文字,其他数字、符号、汉字和空格都不行 //实现思路1,只包含大小写字母 //实现思路2,派除不为大小写字母和数字(0-9),排除数字(0-9),即对大小写字母不排除 
 //不可输入英文字,其他数字、符号、汉字和空格都可以 | 
- 输入框只可(或不可)输入英文与数字
功能描述:输入不合要求的字符立即自动回删!
功能实现关键语句
| //只可输入英文字与数字,其他符号、汉字和空格都不以 //实现思路1,允许字符为大小写字母和数字的输入 //实现思路2,允许大小写字母和数字的输入 onkeyup="value=value.replace(/[\W]/g,'')" //实现思路3,排除字符不为大小写字母和数字(0-9)的输入 //不可输入英文字与数字,其他符号、汉字和空格都可以 //实现思路1,排除字符为大小写字母和数字(0-9)的输入 //实现思路2,允许字符不为大小写字母和数字(0-9)的输入 | 
- 输入框只可(或不可)输入中文
功能描述:输入不合要求的字符立即自动回删!
功能实现关键语句
| 
 //只可输入中文,其他符号字母、数字和空格都不可 //实现思路1,通过允许汉字内码的输入来实现汉字的输入,注意其中0是数字零(此法也适用于只输入繁体中文、日文、韩文) //实现思路2,通过只允许ASCII码为20H-7EH的字符(也就是字母大小写,数字与符号的内码),其他都不允许,如此也就实现禁用中文的目的了(此法也可适用于不允许繁体中文、日文、韩文)。 | 
- 输入框只可输入特定的文字、数字或符号
功能描述:输入不合要求的字符立即自动回删!
功能实现关键语句
| 
 //只可输入中文,其他符号字母、数字和空格都不可 //实现思路1,通过允许汉字内码的输入来实现汉字的输入,注意其中0是数字零(此法也适用于只输入繁体中文、日文、韩文) //实现思路2,通过只允许ASCII码为20H-7EH的字符(也就是字母大小写,数字与符号的内码),其他都不允许,如此也就实现禁用中文的目的了(此法也可适用于不允许繁体中文、日文、韩文)。 | 
- 综合示例
验证台湾居民身份证



实现代码
|  | 
辨析:
replace中的正则表达式是用来对输入内容的限制,并不涉及输入字符串的格式。因此主要是用'|'隔开,表示允许输入的内容。如'/^[\w]/g',该输入框仅允许大小写字母和数字的输入,其中后缀修饰符g表示该输入控制对整个输入框起作用。在replace中'^'表示允许输入。
search中的正则表达式是用来对输入字符串格式的控制,如台湾居民身份证的格式为大写字母开头后面接上9个数字,此时对应的正则表达式为'/^[A-Z]\d{9}$/'。在search中'^'从首个字符开始检查。
附录
常用到正则表达式的符号与说明。
使用正则表达式(Regular Expressions)构造资料格式过滤器(即对输入的字符串的格式进行检查)。
| 符号 | 说明 | 
| ^ | 从输入的资料首个字符开始比较 | 
| $ | 比较到输入资料的最后一个字符 | 
| {n} | 比较前面指定的字符条件n次,n为正整数,例如,\d{n}就是比较输入的字符串中是否为(或含有)n个数字(0-9) | 
| {n,} | 比较前面指定的字符条件至少n次,n为正整数,例如,\w{n,}就是比较是否至少有n个a-z、A-Z或0-9的字符。 | 
| {n,m} | 比较前面指定的字符条件至少n次,最多m次,例如\d{n,m}就是比较数字(0-9)的字符数是否大于或等于n小于或等于m | 
| [x|y|z] | 比较字符是否为x,y,z其中一个 | 
| ^[x|y|z] | 比较首字符是否为x,yz其中一个 | 
| \d | 比较字符是否为0-9的数字 | 
| \D | 比较字符是否不为0-9的数字 | 
| \w | 比较字符是否为a-z、A-Z或0-9 | 
| \W | 比较字符是否不为a-z、A-Z或0-9 | 
参考资料
《全民搞网页——博客|个人站|网店|论坛》程秉辉
表单input中录入资料的检查方法及示例的更多相关文章
- 表单input中disabled提交后得不到值的解决办
		input 按钮的disabled属性,如果设置了,form表单提交后,后台接收不到input的value input的字段当为diabled时时无法获取数值得,所以最近不要用这个,我们可以用read ... 
- 表单input中提示文字value随鼠标焦点移进移出而显示或隐藏的
		jQuery代码 <input value="请输入用户名" type="text"> <input value="请输入密码&qu ... 
- 表单input中disabled提交后得不到值的解决办法
		input的字段当为diabled时时无法获取数值得,所以最近不要用这个,我们可以用readonly带替代,即可解决这类问题. 
- ionic获取表单input的值的两种方法
		1.参数传递法 直接在input处使用 #定义参数的name值,注意在ts中参数的类型 html页面: <ion-input type="text" placeholder= ... 
- HTML中让表单input等文本框为只读不可编辑但可以获取value值的方法;让文本域前面的内容显示在左上角,居中
		HTML中让表单input等文本框为只读不可编辑的方法 有时候,我们希望表单中的文本框是只读的,让用户不能修改其中的信息,如使input text的内容,中国两个字不可以修改 有时候,我们希望 ... 
- js中对arry数组的各种操作小结  瀑布流AJAX无刷新加载数据列表--当页面滚动到Id时再继续加载数据  web前端url传递值 js加密解密  HTML中让表单input等文本框为只读不可编辑的方法  js监听用户的键盘敲击事件,兼容各大主流浏览器  HTML特殊字符
		js中对arry数组的各种操作小结 最近工作比较轻松,于是就花时间从头到尾的对js进行了详细的学习和复习,在看书的过程中,发现自己平时在做项目的过程中有很多地方想得不过全面,写的不够合理,所以说啊 ... 
- 表单提交中get和post方式的区别
		表单提交中get和post方式的区别有5点 1.get是从服务器上获取数据,post是向服务器传送数据. 2.get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一 ... 
- 表单input按钮在各浏览器之间的兼容性
		从网上看了这篇关于表单input按钮的浏览器兼容性问题,总结的还不错,所以copy下来学习下. input按钮在各个浏览器之间的兼容性问题,看下边这段代码: input.item { backgrou ... 
- form表单元素中disabled的元素的值不会提交到服务器
		1.表单元素中disabled的元素的值不会提交到服务器,后台获取的值为null <form id="myForm" action="#" method= ... 
随机推荐
- 如何为编程爱好者设计一款好玩的智能硬件(十)——无线2.4G通信模块研究·一篇说完
			六.温湿度传感器DHT11驱动封装(下):如何为编程爱好者设计一款好玩的智能硬件(六)——初尝试·把温湿度给收集了(下)! 七.点阵字符型液晶显示模块LCD1602驱动封装(上):如何为编程爱好者设计 ... 
- Ubuntu环境搭建系列—Chrome/JDK/Android篇
			其实每次重装Ubuntu系统的时候都要进行一次基本到环境配置,而且每次总会忘记一些环境配置到东西,所以就写下这个博文,方便自己以后重装系统的时候回顾,同时也给大家做为重装系统后基本环境搭建的参考. 因 ... 
- nginx1
			简介: Nginx全程是什么? Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. 安装 配 ... 
- CSS水平垂直居中的几种方法2
			直接进入主题! 一.脱离文档流元素的居中 方法一:margin:auto法 CSS代码: div{ width: 400px; height: 400px; position: relative; b ... 
- css 常见时间轴的做法(————————————————时间轴——————————————————)
			<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ... 
- Redis主从复制问题和扩容问题的解决思路
			转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/106.html?1455867541 一.解决主从复制问题 当使用Redi ... 
- Android开发学习之路-Palette颜色提取工具类使用
			视频(要FQ):https://www.youtube.com/watch?v=5u0dtzXL3PQ Palette是一个在support-v7包中的一个颜色提取工具类,用法比较简单,而且是谷歌官方 ... 
- Java 线程 — ConcurrentHashMap
			ConcurrentHashMap ConcurrentHashMap 结构 采用了分段锁的方法提高COncurrentHashMap并发,一个map里面有一个Segment数组--即多个Segmen ... 
- 被废了的display:box弹性盒模型
			这几天在研究弹性布局,看书中写的是display:box,结果在chrome浏览器中是正常的,想着移动端大部分浏览器也是webkit内核的应该也没啥问题,结果确实没问题,但仔细一看,高度呢?好吧,严重 ... 
- 详解JavaScript模块化开发
			什么是模块化开发? 前端开发中,起初只要在script标签中嵌入几十上百行代码就能实现一些基本的交互效果,后来js得到重视,应用也广泛起来了,jQuery,Ajax,Node.Js,MVC,MVVM等 ... 
