注册验证

本文介绍了一个使用JavaScript实现的表单验证方法,包括用户名、密码、邮箱格式的验证及身份证号的有效性检查。身份证号检查部分涉及省份、出生日期、校验位等详细规则。

[javascript] view plaincopyprint?

  1. $(function () {  
  2.             //当焦点移出txtUserName触发的事件   
  3.             $('#txtUserName').blur(function () {  
  4.                 var username = $.trim($(this).val());  
  5.                 if (username == "") {  
  6.                     $('#username').html('用户名不能为空');  
  7.                 }  
  8.                 else if (username.length < 6 || username.length > 12) {  
  9.                     $('#username').html('用户名必须是6-12位');  
  10.                 }  
  11.                 else {  
  12.                     $('#username').html('用户名输入正确');  
  13.                 }  
  14.             });  
  15.             //验证两次输入的密码是否一致   
  16.             $('#txtPassword').blur(function () {  
  17.                 var password = $.trim($(this).val());  
  18.                 if (password == "") {  
  19.                     $('#password').html('密码不能为空');  
  20.                 }  
  21.                 else {  
  22.                     $('#password').html('密码输入正确');  
  23.                 }  
  24.             });  
  25.             $('#txtPwdOk').blur(function () {  
  26.                 var password = $.trim($('#txtPassword').val());  
  27.                 var passwordok = $.trim($('#txtPwdOk').val());  
  28.                 if (password == passwordok) {  
  29.                     $('#PasswordOk').html('两次输入的密码一致');  
  30.                 }  
  31.                 else {  
  32.                     $('#PasswordOk').html('两次输入的密码不一致');  
  33.                 }  
  34.             });  
  35.             //验证邮箱格式是否正确   
  36.             $('#txtEmail').blur(function () {  
  37.                 var email = $.trim($(this).val());  
  38.                 var reg = /^[_a-zA-Z\d\-\.]+@[_a-zA-Z\d\-]+(\.[_a-zA-Z\d\-]+)+$/; //邮箱验证正则表达式   
  39.   
  40.                 if (email == "") {  
  41.                     $('#email').html('邮箱不能为空');  
  42.                 }  
  43.                 else if (!reg.test($(this).val())) {  
  44.                     $('#email').html('邮箱格式不正确');  
  45.                 }  
  46.                 else {  
  47.                     $('#email').html('输入邮箱正确');  
  48.                 }  
  49.             });  
  50.         });  
  51.         //验证身份证号是否正确   
  52.         var vcity = { 11: "北京", 12: "天津", 13: "河北", 14: "山西", 15: "内蒙古",  
  53.             21: "辽宁", 22: "吉林", 23: "黑龙江", 31: "上海", 32: "江苏",  
  54.             33: "浙江", 34: "安徽", 35: "福建", 36: "江西", 37: "山东", 41: "河南",  
  55.             42: "湖北", 43: "湖南", 44: "广东", 45: "广西", 46: "海南", 50: "重庆",  
  56.             51: "四川", 52: "贵州", 53: "云南", 54: "西藏", 61: "陕西", 62: "甘肃",  
  57.             63: "青海", 64: "宁夏", 65: "新疆", 71: "台湾", 81: "香港", 82: "澳门", 91: "国外"  
  58.         };  
  59.         checktheform = function () {  
  60.             var card = document.getElementById('txtIdCard').value;  
  61.             //是否为空   
  62.             if (card === '') {  
  63.                 document.getElementById('IdCard').innerHTML = "身份证号不能为空";  
  64.                 document.getElementById('txtIdCard').focus;  
  65.                 return false;  
  66.             }  
  67.             //校验长度,类型   
  68.             if (isCardNo(card) === false) {  
  69.                 document.getElementById('IdCard').innerHTML = "身份证号码为15位或者18位,15位全为数字,18位前17位为数字,后一位可以使数字也可以是字母X";  
  70.                 document.getElementById('txtIdCard').focus;  
  71.                 return false;  
  72.             }  
  73.             //检查省份   
  74.             if (checkProvince(card) === false) {  
  75.                 document.getElementById('IdCard').innerHTML = "身份证号码前两位省份输入错误";  
  76.                 document.getElementById('txtIdCard').focus;  
  77.                 return false;  
  78.             }  
  79.             //校验生日   
  80.             if (checkBirthday(card) === false) {  
  81.                 document.getElementById('IdCard').innerHTML = "身份证号码生日不正确";  
  82.                 document.getElementById('txtIdCard').focus();  
  83.                 return false;  
  84.             }  
  85.             //检验位的检测   
  86.             if (checkParity(card) === false) {  
  87.                 document.getElementById('IdCard').innerHTML = "您的身份证校验位不正确";  
  88.                 document.getElementById('txtIdCard').focus();  
  89.                 return false;  
  90.             }  
  91.             document.getElementById('IdCard').innerHTML = "身份证输入正确";  
  92.             return true;  
  93.         };  
  94.         //检查号码是否符合规范,包括长度,类型   
  95.         isCardNo = function (card) {  
  96.             //身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X   
  97.             var reg = /(^\d{15}$)|(^\d{17}(\d|X)$)/;  
  98.             if (reg.test(card) === false) {  
  99.                 return false;  
  100.             }  
  101.             return true;  
  102.         };  
  103.   
  104.         //取身份证前两位,校验省份   
  105.         checkProvince = function (card) {  
  106.             var province = card.substr(0, 2);  
  107.             if (vcity[province] == undefined) {  
  108.                 return false;  
  109.             }  
  110.             return true;  
  111.         };  
  112.         //检查生日是否正确   
  113.         checkBirthday = function (card) {  
  114.             var len = card.length;  
  115.             //身份证15位时,次序为省(3位)市(3位)年(2位)月(2位)日(2位)校验位(3位),皆为数字   
  116.             if (len == '15') {  
  117.                 var re_fifteen = /^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$/;  
  118.                 var arr_data = card.match(re_fifteen);  
  119.                 var year = arr_data[2];  
  120.                 var month = arr_data[3];  
  121.                 var day = arr_data[4];  
  122.                 var birthday = new Date('19' + year + '/' + month + '/' + day);  
  123.                 return verifyBirthday('19' + year, month, day, birthday);  
  124.             }  
  125.             //身份证18位时,次序为省(3位)市(3位)年(4位)月(2位)日(2位)校验位(4位),校验位末尾可能为X   
  126.             if (len == '18') {  
  127.                 var re_eighteen = /^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/;  
  128.                 var arr_data = card.match(re_eighteen);  
  129.                 var year = arr_data[2];  
  130.                 var month = arr_data[3];  
  131.                 var day = arr_data[4];  
  132.                 var birthday = new Date(year + '/' + month + '/' + day);  
  133.                 return verifyBirthday(year, month, day, birthday);  
  134.             }  
  135.             return false;  
  136.         };  
  137.   
  138.         //校验日期   
  139.         verifyBirthday = function (year, month, day, birthday) {  
  140.             var now = new Date();  
  141.             var now_year = now.getFullYear();  
  142.             //年月日是否合理   
  143.             if (birthday.getFullYear() == year && (birthday.getMonth() + 1) == month && birthday.getDate() == day) {  
  144.                 //判断年份的范围(3岁到100岁之间)   
  145.                 var time = now_year - year;  
  146.                 if (time >= 3 && time <= 100) {  
  147.                     return true;  
  148.                 }  
  149.                 return false;  
  150.             }  
  151.             return false;  
  152.         };  
  153.         //校验位的检测   
  154.         checkParity = function (card) {  
  155.             //15位转18位   
  156.             card = changeFivteenToEighteen(card);  
  157.             var len = card.length;  
  158.             if (len == '18') {  
  159.                 var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);  
  160.                 var arrCh = new Array('1''0''X''9''8''7''6''5''4''3''2');  
  161.                 var cardTemp = 0, i, valnum;  
  162.                 for (i = 0; i < 17; i++) {  
  163.                     cardTemp += card.substr(i, 1) * arrInt[i];  
  164.                 }  
  165.                 valnum = arrCh[cardTemp % 11];  
  166.                 if (valnum == card.substr(17, 1)) {  
  167.                     return true;  
  168.                 }  
  169.                 return false;  
  170.             }  
  171.             return false;  
  172.         };  
  173.   
  174.         //15位转18位身份证号   
  175.         changeFivteenToEighteen = function (card) {  
  176.             if (card.length == '15') {  
  177.                 var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);  
  178.                 var arrCh = new Array('1''0''X''9''8''7''6''5''4''3''2');  
  179.                 var cardTemp = 0, i;  
  180.                 card = card.substr(0, 6) + '19' + card.substr(6, card.length - 6);  
  181.                 for (i = 0; i < 17; i++) {  
  182.                     cardTemp += card.substr(i, 1) * arrInt[i];  
  183.                 }  
  184.                 card += arrCh[cardTemp % 11];  
  185.                 return card;  
  186.             }  
  187.             return card;  
  188.         };  
基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究(Matlab代码实现)内容概要:本文围绕“基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究”,介绍了利用Matlab代码实现配电网可靠性的仿真分析方法。重点采用序贯蒙特卡洛模拟法对配电网进行长时间段的状态抽样与统计,通过模拟系统元件的故障与修复过程,评估配电网的关键可靠性指标,如系统停电频率、停电持续时间、负荷点可靠性等。该方法能够有效处理复杂网络结构与设备时序特性,提升评估精度,适用于含分布式电源、电动汽车等新型负荷接入的现代配电网。文中提供了完整的Matlab实现代码与案例分析,便于复现和扩展应用。; 适合人群:具备电力系统基础知识和Matlab编程能力的高校研究生、科研人员及电力行业技术人员,尤其适合从事配电网规划、运行与可靠性分析相关工作的人员; 使用场景及目标:①掌握序贯蒙特卡洛模拟法在电力系统可靠性评估中的基本原理与实现流程;②学习如何通过Matlab构建配电网仿真模型并进行状态转移模拟;③应用于含新能源接入的复杂配电网可靠性定量评估与优化设计; 阅读建议:建议结合文中提供的Matlab代码逐段调试运行,理解状态抽样、故障判断、修复逻辑及指标统计的具体实现方式,同时可扩展至不同网络结构或加入更多不确定性因素进行深化研究。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值