JS常用功能
转载自:http://blog.csdn.net/kalision/article/details/12516103
引用js文件:

<script src="js/demo.js"></script>

按钮

<button type="button" class="button medium button-style1 align-btn-right" value="send" onclick="checkSubmit();">提交</button>

js文件内容:

  1. var b = new Boolean();
  2. b = false;
  3. var b2 = new Boolean();
  4. b2 = false;
  5. function checkSubmit(){
  6. var bbxm = document.getElementById("bbxm").value;
  7. var bbxb = document.getElementById("bbxb").value;
  8. var csrq = document.getElementById("csrq").value;
  9. if(bbxm != ''){
  10. if(bbxb != ''){
  11. if(csrq != ''){
  12. if(isIdCardNo()){
  13. document.form1.submit();
  14. }else{
  15. document.getElementById("identityid").focus();
  16. }
  17. }else{
  18. alert("请选择出生日期!");
  19. document.getElementById("csrq").focus();
  20. }
  21. }else{
  22. alert("请选择性别!");
  23. document.getElementById("bbxb").focus();
  24. }
  25. }else{
  26. alert("姓名不能为空!");
  27. document.getElementById("bbxm").focus();
  28. }
  29. }
  30. function isPassWord(passWord,passWordDemo){
  31. var passWord = document.getElementById(passWord).value;
  32. var passWordDemo = document.getElementById(passWordDemo).value;
  33. if(passWordDemo != passWord){
  34. document.getElementById('spantest2').innerText = "两次输入的密码不一致! ";
  35. b2 = false;
  36. return false;
  37. }else{
  38. document.getElementById('spantest2').innerText = "正确";
  39. b2 = true;
  40. return true;
  41. }
  42. }
  43. function isEmail(email) {
  44. var strEmail=document.getElementById(email).value;
  45. if (strEmail.search(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/) != -1)
  46. {
  47. document.getElementById('spantest').innerText = "邮箱格式正确";
  48. b = true;
  49. return true;
  50. }else{
  51. document.getElementById('spantest').innerText = "邮箱格式错误!";
  52. document.getElementById(email).focus();
  53. b = false;
  54. return false;
  55. }
  56. }
  57. function validatek(){
  58. }
  59. function isIdCardNo() {
  60. var tex = document.getElementById('identityid');
  61. var num = document.getElementById('identityid').value;
  62. if(num != ''){
  63. //alert("您输入的身份证号码是:\n" + num);
  64. num = num.toUpperCase();
  65. //身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X。
  66. if (!(/(^\d{15}$)|(^\d{17}([0-9]|X)$)/.test(num)))
  67. {
  68. alert('输入的身份证号长度不对,或者号码不符合规定!\n身份证号码为15位时,应全为数字,\n身份证号码为18位时,末位可以为数字或X。');
  69. tex.focus();
  70. return false;
  71. }
  72. //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
  73. //下面分别分析出生日期和校验位
  74. var len, re;
  75. len = num.length;
  76. //当身份证为15位时的验证出生日期。
  77. if (len == 15)
  78. {
  79. re = new RegExp(/^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$/);
  80. var arrSplit = num.match(re);
  81. //检查生日日期是否正确
  82. var dtmBirth = new Date('19' + arrSplit[2] + '/' + arrSplit[3] + '/' + arrSplit[4]);
  83. var bGoodDay;
  84. bGoodDay = (dtmBirth.getYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) && (dtmBirth.getDate() == Number(arrSplit[4]));
  85. if (!bGoodDay){
  86. alert('输入的15位身份证号里出生日期不对!');
  87. tex.focus();
  88. return false;
  89. }
  90. }
  91. //当身份证号为18位时,校验出生日期和校验位。
  92. if (len == 18)
  93. {
  94. var year = num.substr(6,4);
  95. //alert("year是:" + year);
  96. var nowDate = new Date();
  97. var nowYear = nowDate.getYear();
  98. if((nowYear - year) > 112){
  99. alert("依照输入的身份证出生日期截止到当前,不属于范围!");
  100. tex.focus();
  101. return false;
  102. }
  103. re = new RegExp(/^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/);
  104. var arrSplit = num.match(re);
  105. //检查生日日期是否正确
  106. var dtmBirth = new Date(arrSplit[2] + "/" + arrSplit[3] + "/" + arrSplit[4]);
  107. var bGoodDay;
  108. bGoodDay = (dtmBirth.getFullYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) && (dtmBirth.getDate() == Number(arrSplit[4]));
  109. if (!bGoodDay){
  110. //alert(dtmBirth.getYear());
  111. //alert(arrSplit[2]);
  112. alert('输入的18位身份证号里出生日期不对!');
  113. tex.focus();
  114. return false;
  115. }
  116. else{
  117. //检验18位身份证的校验码是否正确。
  118. //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
  119. var valnum;
  120. var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
  121. var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
  122. var nTemp = 0, i;
  123. for(i = 0; i < 17; i ++){
  124. nTemp += num.substr(i, 1) * arrInt[i];
  125. }
  126. valnum = arrCh[nTemp % 11];
  127. if (valnum != num.substr(17, 1)){
  128. alert('18位身份证的最后一位校验码不正确!'); //应该为:' + valnum
  129. tex.value='';
  130. tex.focus();
  131. return false;
  132. }
  133. }
  134. }
  135. //验证地区是否有效
  136. 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:"国外 "}
  137. if(aCity[parseInt(num.substr(0,2))] == null){
  138. alert("输入的身份证号前两位地区不对!");
  139. tex.value='';
  140. tex.focus();
  141. return false;
  142. }
  143. return true;
  144. } else{
  145. return true;
  146. }
  147. }

验证表单的js代码段的更多相关文章

  1. js验证表单密码、用户名是否输入--JS的简单应用

    在登录.注册时,我们经常会遇到下面这种情况,如果我们没有输入用户名.密码时,系统会弹出提示框.提示框信息提示内容是我们密码没有输入密码或者用户名等.那么这样的弹出框效果是如何实现的呢?文章标题既然与j ...

  2. jquery.validate.js 验证表单时,在IE当中未验证就直接提交的原因

    jquery.validate.js 验证表单时,在IE当中未验证就直接提交的原因 今天利用了jquery.validate.js来验证表单,发现在火狐.谷歌浏览器当中都可以进行验证,但是在IE系列浏 ...

  3. js验证表单大全

    js验证表单大全 1. 长度限制 <script> function test() { if(document.a.b.value.length>50) { alert(" ...

  4. JS高级---案例:验证表单

    案例:验证表单 <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...

  5. 响应式的账号登录界面模板完整代码,内置form表单和js控件

    响应式的账号登录界面模板,内置form表单和js控件 <!DOCTYPE html> <html lang="en"><head><met ...

  6. tp框架之自动验证表单

    tp框架的create自动加载表单的方法可以自动根据自己定义的要求来验证表单里面的内容,但是由于是在后台执行代码,会拖慢程序运行速度,所以还是建议通过前端js来进行判断,后台只进行数据库的查询以及传值 ...

  7. input 的 pattern 验证表单

    pattern 用于定义验证输入正则表达式 pattern 属性适用于以下 <input> 类型:text, search, url, telephone, email 以及 passwo ...

  8. jquery.validate 使用--验证表单隐藏域

    jQuery validate很不错的一个jQuery表单验证插件.升级到了1.9版的后,发现隐藏表单域验证全部失效,特别是在jquery.ui.tabs.min.js构造的Tabs里的验证. 是因为 ...

  9. ajax验证表单元素规范正确与否 ajax展示加载数据库数据 ajax三级联动

    一.ajax验证表单元素规范正确与否 以用ajax来验证用户名是否被占用为例 1创建表单元素<input type="text" id="t"> 2 ...

随机推荐

  1. CORS跨域请求的限制和解决

    我们模拟一个跨域的请求,一个是8888,一个是8887 //server.js const http = require('http'); const fs = require('fs'); http ...

  2. jQuery 效率提升建议

    jQuery简洁通用的方法集把编码者从繁重的工作中解脱出来,也拉低了进入javascript的门槛,初学者对浏览器兼容性一无所知的情况下,几行代码就可以写出超炫的特效.网上有一篇文章转载比较泛滥,已经 ...

  3. Flashing Fluorescents(状压DP)

    Flashing Fluorescents 时间限制: 1 Sec  内存限制: 128 MB提交: 56  解决: 19[提交] [状态] [讨论版] [命题人:admin] 题目描述 You ha ...

  4. 注解@Component,@Controller,@Service,@Repository简单了解

    Spring 自 2.0 版本开始,陆续引入了一些注解用于简化 Spring 的开发.@Repository注解便属于最先引入的一批,它用于将数据访问层 (DAO 层 ) 的类标识为 Spring B ...

  5. Oracle多表连接方法

    笛卡尔连接[结果集为各表记录的乘积] SELECTt * FROM table_1, table_2, table_n SELECTt * FROM table_1 CROSS JOIN table_ ...

  6. UVA_10139

    The factorial function, n! is defined thus for n a non-negative integer:0! = 1 n! = n×(n−1)! (n > ...

  7. scrapy--dytt(电影天堂)

    喜欢看电影的小伙伴,如果想看新的电影,然后没去看电影院看,没有正确的获得好的方法,大家就可以在电影天堂里进行下载.这里给大家提供一种思路. 1.dytt.py # -*- coding: utf-8 ...

  8. 在程序开发中,++i 与 i++的区别

    在不参与运算的情况下,i++和++i都是在变量的基础加1 ◆在参与运算的情况下 Var i=123; Var j=i++;  先将i的值123赋值给j,之后再自增 j的值为123  i 的值为124 ...

  9. 分析setup/hold电气特性从D触发器内部结构角度

    上图是用与非门实现的D触发器的逻辑结构图,CP是时钟信号输入端,S和R分别是置位和清零信号,低有效; D是信号输入端,Q信号输出端; 这里先说一下D触发器实现的原理:(假设S和R信号均为高,不进行置位 ...

  10. jQuery-laye插件实现 弹框编辑,异步验证,form验证提交

    代码中用到了 jQuery的ajax异步处理,each()循环,submit()页面验证提交form表单,prepend()追加标签,laye插件的弹框效果(如有其它弹框效果可参考官网:http:// ...