javaScript通用数据类型校验

时间 : 11-10-31 栏目 : IT技术 作者 : 文达 评论 : 0 点击 : 337 次

/**
* 取得字符串的字节长度
*/

代码
  1. function strlen(str)
  2. {
  3. var i;
  4. var len;
  5. len = 0;
  6. for(i=0;i<str.length;i++)
  7. {
  8. if (str.charCodeAt(i)>255) len+=2; elselen++;
  9. }
  10. returnlen;
  11. }

<script>render_code();</script>
/*
* 判断是否为数字,是则返回true,否则返回false
*/

代码
  1. function f_check_number(obj)
  2. {
  3. if(/^\d+$/.test(obj.value))
  4. {
  5. return true;
  6. }
  7. else
  8. {
  9. f_alert(obj,"请输入数字");
  10. return false;
  11. }
  12. }

<script>render_code();</script>
/*
* 判断是否为自然数,是则返回true,否则返回false
*/

代码
  1. function f_check_naturalnumber(obj)
  2. {
  3. var s = obj.value;
  4. if(/^[0-9]+$/.test( s ) && (s > 0))
  5. {
  6. return true;
  7. }
  8. else
  9. {
  10. f_alert(obj,"请输入自然数");
  11. return false;
  12. }
  13. }

<script>render_code();</script>
/*
* 判断是否为整数,是则返回true,否则返回false
*/

代码
  1. function f_check_integer(obj)
  2. {
  3. if(/^(\+|-)?\d+$/.test( obj.value ))
  4. {
  5. return true;
  6. }
  7. else
  8. {
  9. f_alert(obj,"请输入整数");
  10. return false;
  11. }
  12. }

<script>render_code();</script>
/*
* 判断是否为实数,是则返回true,否则返回false
*/

代码
  1. function f_check_float(obj)
  2. {
  3. if(/^(\+|-)?\d+($|\.\d+$)/.test( obj.value ))
  4. {
  5. return true;
  6. }
  7. else
  8. {
  9. f_alert(obj,"请输入实数");
  10. return false;
  11. }
  12. }

<script>render_code();</script>
/*
* 校验数字的长度和精度
*/

代码
  1. function f_check_double(obj){
  2. var numReg;
  3. var value = obj.value;
  4. var strValueTemp, strInt, strDec;
  5. var dtype = obj.eos_datatype;
  6. var pos_dtype = dtype.substring(dtype.indexOf("(")+1,dtype.indexOf(")")).split(",");
  7. var len = pos_dtype[0], prec = pos_dtype[1];
  8. try
  9. {
  10. numReg =/[\-]/;
  11. strValueTemp = value.replace(numReg, "");
  12. numReg =/[\+]/;
  13. strValueTemp = strValueTemp.replace(numReg, "");
  14. //整数
  15. if(prec==0){
  16. numReg =/[\.]/;
  17. if(numReg.test(value) == true){
  18. f_alert(obj, "输入必须为整数类型");
  19. return false;
  20. }
  21. }
  22. if(strValueTemp.indexOf(".") < 0 ){
  23. if(strValueTemp.length >( len - prec)){
  24. f_alert(obj, "整数位不能超过"+ (len - prec) +"位");
  25. return false;
  26. }
  27. }else{
  28. strInt = strValueTemp.substr( 0, strValueTemp.indexOf(".") );
  29. if(strInt.length >( len - prec)){
  30. f_alert(obj, "整数位不能超过"+ (len - prec) +"位");
  31. return false;
  32. }
  33. strDec = strValueTemp.substr( (strValueTemp.indexOf(".")+1), strValueTemp.length );
  34. if(strDec.length > prec){
  35. f_alert(obj, "小数位不能超过"+ prec +"位");
  36. return false;
  37. }
  38. }
  39. return true;
  40. }catch(e){
  41. alert("in f_check_double = "+ e);
  42. return false;
  43. }
  44. }

<script>render_code();</script>
/*
* 校验数字的最小最大值
* 返回bool
*/

代码
  1. function f_check_interval(obj)
  2. {
  3. var value = parseFloat(obj.value);
  4. var dtype = obj.eos_datatype;
  5. var pos_dtype = dtype.substring(dtype.indexOf("(")+1,dtype.indexOf(")")).split(",");
  6. var minLimit = pos_dtype[0];
  7. var maxLimit = pos_dtype[1];
  8. var minVal = parseFloat(pos_dtype[0]);
  9. var maxVal = parseFloat(pos_dtype[1]);
  10. if(isNaN(value))
  11. {
  12. f_alert(obj, "值必须为数字");
  13. return false;
  14. }
  15. if((isNaN(minVal) && (minLimit != "-")) || (isNaN(maxVal) && (maxLimit != "+")))
  16. {
  17. f_alert(obj, "边界值必须为数字或-、+");
  18. return false;
  19. }
  20. if(minLimit == "-"&& !isNaN(maxVal))
  21. {
  22. if(value > maxVal)
  23. {
  24. f_alert(obj, "值不能超过"+ maxVal);
  25. return false;
  26. }
  27. }
  28. if(!isNaN(minVal) && maxLimit == "+")
  29. {
  30. if(value < minVal)
  31. {
  32. f_alert(obj, "值不能小于"+ minVal);
  33. return false;
  34. }
  35. }
  36. if(!isNaN(minVal) && !isNaN(maxVal))
  37. {
  38. if(minVal > maxVal)
  39. {
  40. f_alert(obj, "起始值" + minVal + "不能大于终止值"+ maxVal);
  41. }else
  42. {
  43. if(!(value <= maxVal && value >= minVal))
  44. {
  45. f_alert(obj, "值应该在" + minVal + "和" + maxVal + "之间");
  46. return false;
  47. }
  48. }
  49. }
  50. return true;
  51. }

<script>render_code();</script>
/*
用途:检查输入字符串是否只由汉字组成
如果通过验证返回true,否则返回false
*/

代码
  1. function f_check_zh(obj){
  2. if(/^[\u4e00-\u9fa5]+$/.test(obj.value)) {
  3. return true;
  4. }
  5. f_alert(obj,"请输入汉字");
  6. return false;
  7. }

<script>render_code();</script>
/*
* 判断是否为小写英文字母,是则返回true,否则返回false
*/

代码
  1. function f_check_lowercase(obj)
  2. {
  3. if(/^[a-z]+$/.test( obj.value ))
  4. {
  5. return true;
  6. }
  7. f_alert(obj,"请输入小写英文字母");
  8. return false;
  9. }

<script>render_code();</script>
/*
* 判断是否为大写英文字母,是则返回true,否则返回false
*/

代码
  1. function f_check_uppercase(obj)
  2. {
  3. if(/^[A-Z]+$/.test( obj.value ))
  4. {
  5. return true;
  6. }
  7. f_alert(obj,"请输入大写英文字母");
  8. return false;
  9. }

<script>render_code();</script>
/*
* 判断是否为英文字母,是则返回true,否则返回false
*/

代码
  1. function f_check_letter(obj)
  2. {
  3. if(/^[A-Za-z]+$/.test( obj.value ))
  4. {
  5. return true;
  6. }
  7. f_alert(obj,"请输入英文字母");
  8. return false;
  9. }

<script>render_code();</script>
/*
用途:检查输入字符串是否只由汉字、字母、数字组成
输入:
value:字符串
返回:
如果通过验证返回true,否则返回false
*/

代码
  1. function f_check_ZhOrNumOrLett(obj){ //判断是否是汉字、字母、数字组成
  2. var regu = "^[0-9a-zA-Z\u4e00-\u9fa5]+$";
  3. var re = newRegExp(regu);
  4. if(re.test( obj.value )) {
  5. return true;
  6. }
  7. f_alert(obj,"请输入汉字、字母或数字");
  8. return false;
  9. }

<script>render_code();</script>
/*
用途:校验ip地址的格式
输入:strIP:ip地址
返回:如果通过验证返回true,否则返回false;
*/

代码
  1. function f_check_IP(obj)
  2. {
  3. var re=/^(\d+)\.(\d+)\.(\d+)\.(\d+)$/; //匹配IP地址的正则表达式
  4. if(re.test( obj.value ))
  5. {
  6. if( RegExp.$1 <256 && RegExp.$2<256 && RegExp.$3<256 && RegExp.$4<256) return true;
  7. }
  8. f_alert(obj,"请输入合法的计算机IP地址");
  9. return false;
  10. }

<script>render_code();</script>
/*
用途:检查输入对象的值是否符合端口号格式
输入:str 输入的字符串
返回:如果通过验证返回true,否则返回false
*/

代码
  1. function f_check_port(obj)
  2. {
  3. if(!f_check_number(obj))
  4. return false;
  5. if(obj.value < 65536)
  6. return true;
  7. f_alert(obj,"请输入合法的计算机IP地址端口号");
  8. return false;
  9. }

<script>render_code();</script>
/*
用途:检查输入对象的值是否符合网址格式
输入:str 输入的字符串
返回:如果通过验证返回true,否则返回false
*/

代码
  1. function f_check_URL(obj){
  2. var myReg = /^((http:[/][/])?\w+([.]\w+|[/]\w*)*)?$/;
  3. if(myReg.test( obj.value )) return true;
  4. f_alert(obj,"请输入合法的网页地址");
  5. return false;
  6. }

<script>render_code();</script>
/*
用途:检查输入对象的值是否符合E-Mail格式
输入:str 输入的字符串
返回:如果通过验证返回true,否则返回false
*/

代码
  1. function f_check_email(obj){
  2. var myReg = /^([-_A-Za-z0-9\.]+)@([_A-Za-z0-9]+\.)+[A-Za-z0-9]{2,3}$/;
  3. if(myReg.test( obj.value )) return true;
  4. f_alert(obj,"请输入合法的电子邮件地址");
  5. return false;
  6. }

<script>render_code();</script>
/*
要求:一、移动电话号码为11或12位,如果为12位,那么第一位为0
二、11位移动电话号码的第一位和第二位为"13"
三、12位移动电话号码的第二位和第三位为"13"
用途:检查输入手机号码是否正确
输入:
s:字符串
返回:
如果通过验证返回true,否则返回false
*/

代码
  1. function f_check_mobile(obj){
  2. var regu =/(^[1][3][0-9]{9}$)|(^0[1][3][0-9]{9}$)/;
  3. var re = newRegExp(regu);
  4. if(re.test( obj.value )) {
  5. return true;
  6. }
  7. f_alert(obj,"请输入正确的手机号码");
  8. return false;
  9. }

<script>render_code();</script>
/*
要求:一、电话号码由数字、"("、")"和"-"构成
二、电话号码为3到8位
三、如果电话号码中包含有区号,那么区号为三位或四位
四、区号用"("、")"或"-"和其他部分隔开
用途:检查输入的电话号码格式是否正确
输入:
strPhone:字符串
返回:
如果通过验证返回true,否则返回false
*/

代码
  1. function f_check_phone(obj)
  2. {
  3. var regu =/(^([0][1-9]{2,3}[-])?\d{3,8}(-\d{1,6})?$)|(^\([0][1-9]{2,3}\)\d{3,8}(\(\d{1,6}\))?$)|(^\d{3,8}$)/;
  4. var re = newRegExp(regu);
  5. if(re.test( obj.value )) {
  6. return true;
  7. }
  8. f_alert(obj,"请输入正确的电话号码");
  9. return false;
  10. }

<script>render_code();</script>
/* 判断是否为邮政编码 */

代码
  1. function f_check_zipcode(obj)
  2. {
  3. if(!f_check_number(obj))
  4. return false;
  5. if(obj.value.length!=6)
  6. {
  7. f_alert(obj,"邮政编码长度必须是6位");
  8. return false;
  9. }
  10. return true;
  11. }

<script>render_code();</script>
/*
用户ID,可以为数字、字母、下划线的组合,
第一个字符不能为数字,且总长度不能超过20。
*/

代码
  1. function f_check_userID(obj)
  2. {
  3. var userID = obj.value;
  4. if(userID.length > 20)
  5. {
  6. f_alert(obj,"ID长度不能大于20");
  7. return false;
  8. }
  9. if(!isNaN(userID.charAt(0)))
  10. {
  11. f_alert(obj,"ID第一个字符不能为数字");
  12. return false;
  13. }
  14. if(!/^\w{1,20}$/.test(userID))
  15. {
  16. f_alert(obj,"ID只能由数字、字母、下划线组合而成");
  17. return false;
  18. }
  19. return true;
  20. }

<script>render_code();</script>
/*
功能:验证身份证号码是否有效
提示信息:未输入或输入身份证号不正确!
使用:f_check_IDno(obj)
返回:bool
*/

代码
  1. function f_check_IDno(obj)
  2. {
  3. 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:"国外"};
  4. var iSum = 0;
  5. var info = "";
  6. var strIDno = obj.value;
  7. var idCardLength = strIDno.length;
  8. if(!/^\d{17}(\d|x)$/i.test(strIDno)&&!/^\d{15}$/i.test(strIDno))
  9. {
  10. f_alert(obj,"非法身份证号");
  11. return false;
  12. }
  13. //在后面的运算中x相当于数字10,所以转换成a
  14. strIDno = strIDno.replace(/x$/i,"a");
  15. if(aCity[parseInt(strIDno.substr(0,2))]==null)
  16. {
  17. f_alert(obj,"非法地区");
  18. return false;
  19. }
  20. if(idCardLength==18)
  21. {
  22. sBirthday=strIDno.substr(6,4)+"-"+Number(strIDno.substr(10,2))+"-"+Number(strIDno.substr(12,2));
  23. var d = new Date(sBirthday.replace(/-/g,"/"))
  24. if(sBirthday!=(d.getFullYear()+"-"+ (d.getMonth()+1) + "-"+ d.getDate()))
  25. {
  26. f_alert(obj,"非法生日");
  27. return false;
  28. }
  29. for(var i = 17;i>=0;i --)
  30. iSum += (Math.pow(2,i) % 11) * parseInt(strIDno.charAt(17 - i),11);
  31. if(iSum%11!=1)
  32. {
  33. f_alert(obj,"非法身份证号");
  34. return false;
  35. }
  36. }
  37. else if(idCardLength==15)
  38. {
  39. sBirthday = "19" + strIDno.substr(6,2) + "-" + Number(strIDno.substr(8,2)) + "-"+ Number(strIDno.substr(10,2));
  40. var d = new Date(sBirthday.replace(/-/g,"/"))
  41. var dd = d.getFullYear().toString() + "-" + (d.getMonth()+1) + "-"+ d.getDate();
  42. if(sBirthday != dd)
  43. {
  44. f_alert(obj,"非法生日");
  45. return false;
  46. }
  47. }
  48. return true;
  49. }

除非注明,文章均为( 文达 )原创,转载请保留链接: http://www.zhoujunzhao.com/?p=14

javaScript通用数据类型校验:等您坐沙发呢!

发表评论

您必须 [ 登录 ] 才能发表留言!