input的表单验证(不断更新中~~)
1 手机号验证
- <input type="tel" id="phone" name="phone" placeholder="请输入联系电话" maxlength="11" onkeyup="this.value=this.value.replace(/[^0-9]/g,'')"
onafterpaste="this.value=this.value.replace(/[^0-9]/g,'')" >- <script>
- function checkPhone(phone){
- var regu = /^(0[0-9]{2,3}\-)?([2-9][0-9]{6,7})+(\-[0-9]{1,4})?$|(^(13[0-9]|15[0-9]|17[0-9]|18[0-9])\d{8}$)/;
- if(!(regu.test(phone))){
- return true;
- } else{
- return false;
- }
- }
- $("#phone").blur(function(){ //手机验证
- var tel=$(this)[0];
- if(tel.value.length!=11){
- console.log("请输入正确的手机号");//增加错误提示
- $('[name="phone"]').focus();
- return ;
- }
- if(tel.value.length==11){
- if(checkPhone(tel.value)){
- console.log("请填写有效的11位手机号码");//错误提示
- $('[name="phone"]').focus();
- return ;
- }
- }
- });
- </script>
2 email验证
- <input type="email" id="email" name="email" placeholder="请输入电邮地址" onblur="testEmail($(this).val())">
- <script>
- function testEmail(str){
- var reg = /^([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+\.[a-zA-Z]{2,3}$/;
- if(!reg.test(str)){
- console.log("请输入正确的电邮地址");//错误提示
- $('[name="email"]').focus();
- return ;
- }
- }
- </script>
3 身份证号验证
- <input type="text" maxlength="18" class="input" placeholder="请输入您的身份证" id="icCode" name="icCode"
onblur="validIdCard($(this).val())" onkeyup="value=value.replace(/[^\a-\z\A-\Z0-9]/g,'')"
onpaste="value=value.replace(/[^\a-\z\A-\Z0-9]/g,'')" oncontextmenu="value=value.replace(/[^\a-\z\A-\Z0-9]/g,'')" oncontextmenu="return false;" />- <script>
- function validIdCard(icCode) {
- if($.trim($('[name="icCode"]').val()) == '') {
- console.log("身份证号码不能为空!");
- $('[name="icCode"]').focus();
- return;
- } else if(!validIcCode($.trim($('[name="icCode"]').val()))) {
- $('[name="icCode"]').focus();
- return;
- }
- }
- function validIcCode(iIdNo) {
- var aCity = {
- 11: "北京",
- 12: "天津",
- 13: "河北",
- 14: "山西",
- 15: "内蒙古",
- 21: "辽宁",
- 22: "吉林",
- 23: "黑龙江",
- 31: "上海",
- 32: "江苏",
- 33: "浙江",
- 34: "安徽",
- 35: "福建",
- 36: "江西",
- 37: "山东",
- 41: "河南",
- 42: "湖北",
- 43: "湖南",
- 44: "广东",
- 45: "广西",
- 46: "海南",
- 50: "重庆",
- 51: "四川",
- 52: "贵州",
- 53: "云南",
- 54: "西藏",
- 61: "陕西",
- 62: "甘肃",
- 63: "青海",
- 64: "宁夏",
- 65: "新疆",
- 71: "台湾",
- 81: "香港",
- 82: "澳门",
- 91: "国外"
- };
- var iSum = 0;
- var info = "";
- if(!/^\d{17}(\d|x)$/i.test(iIdNo)) {
- console.log("你输入的身份证长度或格式错误");
- return false;
- }
- iIdNo = iIdNo.replace(/x$/i, "a");
- if(aCity[parseInt(iIdNo.substr(0, 2))] == null) {
- console.log("你的身份证地区非法");
- return false;
- }
- sBirthday = iIdNo.substr(6, 4) + "-" + Number(iIdNo.substr(10, 2)) + "-" + Number(iIdNo.substr(12, 2));
- var d = new Date(sBirthday.replace(/-/g, "/"));
- if(sBirthday != (d.getFullYear() + "-" + (d.getMonth() + 1) + "-" + d.getDate())) {
- console.log("身份证上的出生日期非法");
- return false;
- }
- for(var i = 17; i >= 0; i--) iSum += (Math.pow(2, i) % 11) * parseInt(iIdNo.charAt(17 - i), 11);
- if(iSum % 11 != 1) {
- console.log("你输入的身份证号非法");
- return false;
- } else {
- return true;
- }
- }
- </script>
4 非空验证
- function isNullValue(val) {
- if (val == '') {return true;}
- var regu = "^[ ]+$|^[ ]+$";
- var re = new RegExp(regu);
- if (re.test(val) == true) {return true;}
- return false;
- }
5 url验证
- 1 <input name="www" type="text" id="www" size="20" maxlength="70" onblur="checkform1();">
- 2
- 3 <script language="javascript">
- 4 function isURL(str) {
- 5 return !!str.match(/(((^https?:(?:\/\/)?)(?:[-;:&=\+\$,\w]+@)?[A-Za-z0-9.-]+|(?:www.|[-;:&=\+\$,\w]+@)[A-Za-z0-9.-]+)((?:\/[\+~%\/.\w-_]*)?\??(?:[-\+=&;%@.\w_]*)#?(?:[\w]*))?)$/g);
- 6 }
- 7
- 8 function checkform1() {
- 9 var www = $('#www').val();
- 10 if(www == "") {
- 11 console.log("请输入个人主页地址!");
- 12 $('#www').val('').focus();
- 13 return;
- 14 } else {
- 15 if(!isURL(www)) {
- 16 console.log("您输入的个人主页地址不合法!");
- 17 $('#www').val('').focus();
- 18 return;
- 19 }
- 20 }
- 21
- 22 }
- 23 </script>
6 日期格式及开始时间不得大于结束时间验证
- <input type="text" name="beginTime" id="beginTime" value="" onchange="changeDate(this)"/>
- <input type="text" name="engTime" id="engTime" value="" onchange="changeDate(this)" />
- <script language="javascript">
- function RQcheck(RQ) {
- var date = RQ;
- var result = date.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);
- if (result == null)
- return false;
- var d = new Date(result[1], result[3] - 1, result[4]);
- return (d.getFullYear() == result[1] && (d.getMonth() + 1) == result[3] && d.getDate() == result[4]);
- }
- function CheckAdd(input) {//验证日期格式,假定规定的日期格式是YYYY-MM-DD
- var ret = true;
- if (!RQcheck($(input).val())) {
- console.log("请输入正确的日期格式");
- $(input).focus();
- return false;
- }
- return ret;
- }
- function getDate(date){//格式化日期格式,特别是月日小于10的补零
- var month=(date.getMonth()+1)>9?(date.getMonth()+1):('0'+(date.getMonth()+1));
- var IDate=date.getDate()>9?date.getDate():('0'+date.getDate());
- var strDate=date.getFullYear()+'-'+month+'-'+IDate;
- return strDate;
- }
- function changeDate(input){//结束日期必须大于等于开始日期
- var thisDate=getDate(new Date($(input).val()));
- var beginTime=getDate(new Date($('#beginTime').val()));
- var engTime=getDate(new Date($('#engTime').val()));
- if(!CheckAdd(input)){
- $(input).val('').focus()
- }else if(beginTime>engTime){
- console.log('填写的动工日期必须大于当前日期.')
- $(input).val('').focus()
- }else{
- $(input).val(thisDate)
- }
- }
- </script>
7 英文,数字,中文验证
- 只能输入英文
- <input type="text" onkeyup="value=value.replace(/[^a-zA-Z]/g,'')">
- <br />
- <br />
- 只能输入英文
- <input type="text" onkeyup="value=value.replace(/[^\a-\z\A-\Z]/g,'')"
- onpaste="return false"
- oncontextmenu="return false" />
- 无法粘贴,右键不会弹出粘贴菜单
- <br />
- <br />
- 只能输入数字:
- <input onkeyup="this.value=this.value.replace(/\D/g,'')"
- onafterpaste="this.value=this.value.replace(/\D/g,'')">
- <br />
- <br />
- 只能输入数字,小数点:
- <input name="price" type="text"
- onkeyup="value=value.replace(/[^\d\.]/g,'')">
- <br />
- <br />
- 只能输入数字,小数点,下划线:
- <input name="price" type="text"
- onkeyup="value=value.replace(/[^\d\._]/g,'')">
- <br />
- <br />
- 只能输入英文和数字:
- <input onkeyup="value=value.replace(/[\W]/g,'') "
- onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))">
- <br />
- <br />
- 只能输入汉字:
- <input onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')"
- onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))">
- <br />
- <br />
- 禁止输入法输入:
- <input type="text" style="ime-mode: disabled">
- 无法切换输入法
- <br />
- <br />
- 只能输入中文、英文、数字、@符号和.符号:
- <input type="text"
- onkeyup="value=value.replace(/[^\a-\z\A-\Z0-9\u4E00-\u9FA5\@\.]/g,'')">
- <br />
- <br />
- 不能为空:
- <input onblur="if(this.value.replace(/^ +| +$/g,'')=='')alert('不能为空!')">
8 数值型验证
- <input type="text" name="" id="" value="" maxlength="10" onblur="validationNum(this)" onkeyup="value=value.replace(/[^\d\.-]/g,'')"/>
- <script language="javascript">
- function validationNum(input) {
- var val = $(input).val();
- // var regu = /^\-?[1-9]\d*$/g ;//只能输入正负整数
- // var regu = /^(\-?0\.[0-9]*)$|(\-?[1-9][0-9]*\.?[0-9]*$)|^0$/g ;//可输入正负数(包括有小数的,0)
- var regu = /^[1-9]\d*$/g; //只能输入正整数
- if(val != "") {
- if(!regu.test(val)) {
- console.log('只能输入数值,正数的首位不能为0,负数的数值部分首位不能为0');
- $(input).val('');
- }
- }
- console.log(val.length)
- }
- </script>
9 银行卡号验证
- <input type="text" name="bankNum" id="bankNum" value="" onblur="CheckBankNo($(this).val())" onkeyup="value=value.replace(/[^\d]/g,'')"/>
- <script language="javascript">
- //银行卡号Luhn校验算法
- //luhn校验规则:16位银行卡号(19位通用):
- //1.将未带校验位的 15(或18)位卡号从右依次编号 1 到 15(18),位于奇数位号上的数字乘以 2。
- //2.将奇位乘积的个十位全部相加,再加上所有偶数位上的数字。
- //3.将加法和加上校验位能被 10 整除。
- //bankno为银行卡号
- function luhnCheck(bankno){
- var lastNum=bankno.substr(bankno.length-1,1);//取出最后一位(与luhn进行比较)
- var first15Num=bankno.substr(0,bankno.length-1);//前15或18位
- var newArr=new Array();
- for(var i=first15Num.length-1;i>-1;i--){ //前15或18位倒序存进数组
- newArr.push(first15Num.substr(i,1));
- }
- var arrJiShu=new Array(); //奇数位*2的积 <9
- var arrJiShu2=new Array(); //奇数位*2的积 >9
- var arrOuShu=new Array(); //偶数位数组
- for(var j=0;j<newArr.length;j++){
- if((j+1)%2==1){//奇数位
- if(parseInt(newArr[j])*2<9)
- arrJiShu.push(parseInt(newArr[j])*2);
- else
- arrJiShu2.push(parseInt(newArr[j])*2);
- }
- else //偶数位
- arrOuShu.push(newArr[j]);
- }
- var jishu_child1=new Array();//奇数位*2 >9 的分割之后的数组个位数
- var jishu_child2=new Array();//奇数位*2 >9 的分割之后的数组十位数
- for(var h=0;h<arrJiShu2.length;h++){
- jishu_child1.push(parseInt(arrJiShu2[h])%10);
- jishu_child2.push(parseInt(arrJiShu2[h])/10);
- }
- var sumJiShu=0; //奇数位*2 < 9 的数组之和
- var sumOuShu=0; //偶数位数组之和
- var sumJiShuChild1=0; //奇数位*2 >9 的分割之后的数组个位数之和
- var sumJiShuChild2=0; //奇数位*2 >9 的分割之后的数组十位数之和
- var sumTotal=0;
- for(var m=0;m<arrJiShu.length;m++){
- sumJiShu=sumJiShu+parseInt(arrJiShu[m]);
- }
- for(var n=0;n<arrOuShu.length;n++){
- sumOuShu=sumOuShu+parseInt(arrOuShu[n]);
- }
- for(var p=0;p<jishu_child1.length;p++){
- sumJiShuChild1=sumJiShuChild1+parseInt(jishu_child1[p]);
- sumJiShuChild2=sumJiShuChild2+parseInt(jishu_child2[p]);
- }
- //计算总和
- sumTotal=parseInt(sumJiShu)+parseInt(sumOuShu)+parseInt(sumJiShuChild1)+parseInt(sumJiShuChild2);
- //计算luhn值
- var k= parseInt(sumTotal)%10==0?10:parseInt(sumTotal)%10;
- var luhn= 10-k;
- if(lastNum==luhn){
- console.log("验证通过");
- return true;
- }else{
- console.log("银行卡号必须符合luhn校验");
- return false;
- }
- }
- //检查银行卡号
- function CheckBankNo(bankno) {
- var bankno = bankno.replace(/\s/g,'');
- if(bankno == "") {
- console.log("请填写银行卡号");
- return false;
- }
- if(bankno.length < 16 || bankno.length > 19) {
- console.log("银行卡号长度必须在16到19之间");
- return false;
- }
- var num = /^\d*$/;//全数字
- if(!num.exec(bankno)) {
- console.log("银行卡号必须全为数字");
- return false;
- }
- //开头6位
- var strBin = "10,18,30,35,37,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,58,60,62,65,68,69,84,87,88,94,95,98,99";
- if(strBin.indexOf(bankno.substring(0, 2)) == -1) {
- console.log("银行卡号开头6位不符合规范");
- return false;
- }
- //Luhn校验
- if(!luhnCheck(bankno)){
- return false;
- }
- return true;
- }
- </script>
10 file类型的必填验证
file 类型的value是只读属性,不能由js去控制,在实际项目中需要编辑,上传预览, 但是后台传值过来value获取一直都是空
解决: 在input上规定自定义属性,用自定义去判断是不是已经有了图
题外 错误信息提示
- <style>
- .toast-box {
- position: absolute;
- z-index: ;
- max-width: %;
- top: %;
- left: %;
- }
- .popover-success {
- opacity: ;
- display: block;
- text-align: center;
- font-size:1.2rem;
- color: #fff;
- padding: .7em 1em;
- white-space: nowrap;
- box-sizing: border-box;
- border-radius: 6px;
- background-color: rgba(, , , 0.6);
- line-height: 1.6;
- letter-spacing: 2px;
- -webkit-transform: translateX(-%) scale();
- -ms-transform: translateX(-%) scale();
- transform: translateX(-%) scale();
- -webkit-transition: .2s ease;
- transition: .2s ease;
- }
- </style>
- function toast_1(message) {
- var toastBox = "<div class='toast-box'><span class='popover-success'>" + message + "</span></div>";
- $('body').append(toastBox);
- $(".toast-box").fadeOut(,function(){
- $(".toast-box").remove();
- });
- }
很多都是网上找到的加之前用到的,如果有任何侵权麻烦联系我,主要是整理,谢谢~~
input的表单验证(不断更新中~~)的更多相关文章
- jquery插件-表单验证插件-提示信息中文化与定制提示信息
接上一篇 2)messages 提示:修改默认的提示信息最简单的方法是引入message_zh.js文件即可! 如果需要在validate()方法内提示则可以使用本选项 类型:Object 说明:自定 ...
- web框架-(六)Django补充---form表单验证
一.form表单验证 1. 常规html页面的form表单验证 常规页面中,如果想实现对表单中用户输入信息的数据验证,需要配合Ajax来实现. 使用前我们先来熟悉下函数参数:request,其中包含的 ...
- jquery validate表单验证插件-推荐
1 表单验证的准备工作 在开启长篇大论之前,首先将表单验证的效果展示给大家. 1.点击表单项,显示帮助提示 2.鼠标离开表单项时,开始校验元素 3.鼠标离开后的正确.错误提示及鼠标移入时的帮 ...
- jquery validate表单验证插件
1 表单验证的准备工作 在开启长篇大论之前,首先将表单验证的效果展示给大家. 1.点击表单项,显示帮助提示 2.鼠标离开表单项时,开始校验元素 3.鼠标离开后的正确.错误提示及鼠标移入时的帮 ...
- 表单验证——JavaScript和Jquery版
1.轻量级的JavaScript表单验证 在应用中引用 validator.min.js 文件 <script type="text/javascript" src=&quo ...
- angularjs学习第四天笔记(第一篇:简单的表单验证)
您好,我是一名后端开发工程师,由于工作需要,现在系统的从0开始学习前端js框架之angular,每天把学习的一些心得分享出来,如果有什么说的不对的地方,请多多指正,多多包涵我这个前端菜鸟,欢迎大家的点 ...
- FormValidator表单验证
所需的库文件 红色框内是所需要的JavaScript库文件. <%@ page language="java" contentType="text/html; ch ...
- jquery validate表单验证插件的基本使用方法及功能拓展
1 表单验证的准备工作 在开启长篇大论之前,首先将表单验证的效果展示给大家. 1.点击表单项,显示帮助提示 2.鼠标离开表单项时,开始校验元素 3.鼠标离开后的正确.错误提示及鼠标移入时的帮助提 ...
- 微信小程序之表单验证
表单验证 何为表单验证呢? 百度百科给出的回答是这样的: 表单验证是javascript中的高级选项之一.JavaScript 可用来在数据被送往服务器前对 HTML 表单中的这些输入数据进行验证 [ ...
随机推荐
- jdk不同版本的垃圾收集器
- Django项目:CMDB(服务器硬件资产自动采集系统)--06--06CMDB测试Linux系统采集硬件数据的命令01
#base.py # ————————01CMDB获取服务器基本信息———————— from config import settings #配置文件 class BasePlugin(object ...
- 阿里OSS ajax方式 web直传
部分js代码 send_request = function(){//这是从后台获取认证策略等信息. var htmlobj=$.ajax({url:root+"/service/polic ...
- Delphi 设计模式:《HeadFirst设计模式》Delphi2007代码---单例模式之ChocolateBoiler[转]
1 2{<HeadFirst设计模式>之单例模式 } 3{ 编译工具: Delphi2007 for win32 } 4{ E-Mail : guzh-0417@163.com ...
- Spring-session整合到Redis
闲来无事,学习一下spring的session管理,作为一个初学者,我了解到了如下内容: 1.为何要用Spring-session 在传统单机web应用中,一般使用tomcat/jetty等web容器 ...
- Entity Framework底层操作封装V2版本号(5)
这个框架到如今最大的变化立即就要出现了,哪就是对缓存的使用.由于系统常常要去读取数据库数据.可是大家知道.数据库的处理能力是有限的,所以对于一些数据量不大,可是又 须要常常去读取的功能来说.更好的方法 ...
- mongodb+nodejs 增删查的demo
1.启动数据库 启动完成后显示 端口号是27017 2.创建数据库 创建一个名为mydb的数据库 3.先查询一下当然的用户,再新增一个 4.创建数据表,查询所有的表 db.createCollec ...
- 评价目标检测(object detection)模型的参数:IOU,AP,mAP
首先我们为什么要使用这些呢? 举个简单的例子,假设我们图像里面只有1个目标,但是定位出来10个框,1个正确的,9个错误的,那么你要按(识别出来的正确的目标/总的正确目标)来算,正确率100%,但是其实 ...
- spring入门案例分析及原理
Springmvc执行原理: 一. 入门案例的执行流程 1. 当启动Tomcat服务器的时候,因为配置了load-on-startup标签,所以会创建DispatcherServlet对象,就会加载s ...
- ECS应用管理最佳实践
前言 即使在CloudNative发展如火如荼的当下,ECS应用(直接将应用部署在ECS上,不使用容器)仍然占了相当大的比重,原因主要在于相对容器化应用,ECS应用由于不需要容器的运行时环境和类似K8 ...