资讯专栏INFORMATION COLUMN

JavaScript常用脚本集锦7

lindroid / 924人阅读

摘要:将加法和加上校验位能被整除。下面分别分析出生日期和校验位检查生日日期是否正确输入的身份证号里出生日期不对将位身份证转成位校验位按照的规定生成,可以认为是数字。校验位按照的规定生成,可以认为是数字。表示全部为中文为不全是中文,或没有中文。

判断是否是合理的银行卡卡号

</>复制代码

  1. //Description: 银行卡号Luhm校验
  2. //Luhm校验规则:16位银行卡号(19位通用):
  3. // 1.将未带校验位的 15(或18)位卡号从右依次编号 1 到 15(18),位于奇数位号上的数字乘以 2。
  4. // 2.将奇位乘积的个十位全部相加,再加上所有偶数位上的数字。
  5. // 3.将加法和加上校验位能被 10 整除。
  6. //bankno为银行卡号 banknoInfo为显示提示信息的DIV或其他控件
  7. function luhmCheck(bankno){
  8. var lastNum=bankno.substr(bankno.length-1,1);//取出最后一位(与luhm进行比较)
  9. var first15Num=bankno.substr(0,bankno.length-1);//前15或18位
  10. var newArr=new Array();
  11. for(var i=first15Num.length-1;i>-1;i--){ //前15或18位倒序存进数组
  12. newArr.push(first15Num.substr(i,1));
  13. }
  14. var arrJiShu=new Array(); //奇数位*2的积 <9
  15. var arrJiShu2=new Array(); //奇数位*2的积 >9
  16. var arrOuShu=new Array(); //偶数位数组
  17. for(var j=0;j9 的分割之后的数组个位数
  18. var jishu_child2=new Array();//奇数位*2 >9 的分割之后的数组十位数
  19. for(var h=0;h9 的分割之后的数组个位数之和
  20. var sumJiShuChild2=0; //奇数位*2 >9 的分割之后的数组十位数之和
  21. var sumTotal=0;
  22. for(var m=0;m
  23. 代码来源: http://blog.csdn.net/ywt_go/article/details/7730380

  24. 判断是否是合理的IP地址
  25. </>复制代码

    1. /**
    2. *
    3. * @descrition:判断是否是合理的IP地址
    4. * @param:str->待验证的IP地址
    5. * @return :true合理的IP地址
    6. *
    7. */
    8. var isIP = function (str) {
    9. var pattern = /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?).){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;
    10. return pattern.test(str);
    11. }
  26. 代码来源:https://gist.github.com/hehongwei44/3659b0c244aa0b56d265

  27. 判断输入的参数是否是个合格的URL
  28. </>复制代码

    1. /**
    2. * @descrition:判断输入的参数是否是个合格的URL,由于url的灵活性和多样性,一下代码并不能测试所有的url都是合法的
    3. * @param:str->待判断的url参数
    4. * @return :true表示符合改正则。
    5. **/
    6. var isURL = function (str) {
    7. var strRegex = "^((https|http|ftp|rtsp|mms)?://)"
    8. + "?(([0-9a-z_!~*"().&=+$%-]+: )?[0-9a-z_!~*"().&=+$%-]+@)?" //ftp的user@
    9. + "(([0-9]{1,3}.){3}[0-9]{1,3}" // IP形式的URL- 199.194.52.184
    10. + "|" // 允许IP和DOMAIN(域名)
    11. + "([0-9a-z_!~*"()-]+.)*" // 域名- www.
    12. + "([0-9a-z][0-9a-z-]{0,61})?[0-9a-z]." // 二级域名
    13. + "[a-z]{2,6})" // first level domain- .com or .museum
    14. + "(:[0-9]{1,4})?" // 端口- :80
    15. + "((/?)|"
    16. + "(/[0-9a-z_!~*"().;?:@&=+$,%#-]+)+/?)$";
    17. var re = new RegExp(strRegex);
    18. return re.test(str);
    19. }
  29. 代码来源:https://gist.github.com/hehongwei44/ce075343fc539c1e4c75

  30. 判断输入的参数是否是国内合法的邮编地址
  31. </>复制代码

    1. /**
    2. *
    3. * @descrition:判断输入的参数是否是国内合法的邮编地址(ps:国内不包含国外的邮编)
    4. * @link: http://www.youbianku.com/%E9%A6%96%E9%A1%B5
    5. * @param: str为待验证的邮编号码
    6. * @return: true表示为合法的邮编号码
    7. *
    8. */
    9. var isPostcode = function(str) {
    10. //国内邮编以0-8开头的6为数字
    11. var pattern = /^[0-8]d{5}$/;
    12. return pattern.test(str);
    13. }
  32. 代码来源:https://gist.github.com/hehongwei44/4db037bfc161a3e0f776

  33. 判断输入的参数是否是个合格的QQ号码
  34. </>复制代码

    1. /**
    2. *
    3. * @descrition:判断输入的参数是否是个合格的QQ号码
    4. * @param->str:待验证的参数
    5. * @return: true验证成功
    6. */
    7. var isQQ = function(str) {
    8. /**
    9. *@descrition:规则
    10. * 1-9开头,最少5位。
    11. */
    12. var pattern = /^[1-9][0-9]{4,}$/
    13. return pattern.test(str);
    14. }
  35. 代码来源:https://gist.github.com/hehongwei44/64ceba194958e6ebedfb

  36. 判断输入的参数是否是个合格的固定电话号码
  37. </>复制代码

    1. /**
    2. * @descrition:判断输入的参数是否是个合格的固定电话号码。
    3. * @param:str->待验证的固定电话号码。
    4. * @return : true表示验证合格。
    5. *
    6. **/
    7. var isfixedphone = function(str) {
    8. /**
    9. *
    10. * @desctition:规则->区号3-4位,号码7-8位,可以有分机号,分机号为3-4为,格式如下:"0775-85333333-123"
    11. *
    12. */
    13. var pattern = /^d{3,4}-d{7,8}(-d{3,4})?$/;
    14. return pattern.test(str);
    15. }
  38. 代码来源:https://gist.github.com/hehongwei44/a62123e422316062301c

  39. 判断输入的参数是否是个合格的手机号码
  40. </>复制代码

    1. /**
    2. *
    3. * @descrition:判断输入的参数是否是个合格的手机号码,不能判断号码的有效性,有效性可以通过运营商确定。
    4. * @param:str ->待判断的手机号码
    5. * @return: true表示合格输入参数
    6. *
    7. */
    8. var isCellphone = function(str) {
    9. /**
    10. *@descrition:手机号码段规则
    11. * 13段:130、131、132、133、134、135、136、137、138、139
    12. * 14段:145、147
    13. * 15段:150、151、152、153、155、156、157、158、159
    14. * 17段:170、176、177、178
    15. * 18段:180、181、182、183、184、185、186、187、188、189
    16. *
    17. */
    18. var pattern = /^(13[0-9]|14[57]|15[012356789]|17[0678]|18[0-9])d{8}$/;
    19. return pattern.test(str);
    20. }
  41. 代码来源:https://gist.github.com/hehongwei44/2bbfbb5d6dccea3b2285

  42. 判断输入的参数是否是个合格标准的邮箱
  43. </>复制代码

    1. /**
    2. *
    3. * @descrition:判断输入的参数是否是个合格标准的邮箱,并不能判断是否有效,有效只能通过邮箱提供商确定。
    4. * @param:str ->待验证的参数。
    5. * @return -> true表示合格的邮箱。
    6. *
    7. */
    8. var isEmail = function(str){
    9. /**
    10. * @descrition:邮箱规则
    11. * 1.邮箱以a-z、A-Z、0-9开头,最小长度为1.
    12. * 2.如果左侧部分包含-、_、.则这些特殊符号的前面必须包一位数字或字母。
    13. * 3.@符号是必填项
    14. * 4.右则部分可分为两部分,第一部分为邮件提供商域名地址,第二部分为域名后缀,现已知的最短为2位。最长的为6为。
    15. * 5.邮件提供商域可以包含特殊字符-、_、.
    16. */
    17. var pattern = /^([a-zA-Z0-9]+[-_.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[-_.]?)*[a-zA-Z0-9]+.[a-zA-Z]{2,6}$/;
    18. return pattern.test(str);
    19. }
  44. 代码来源:https://gist.github.com/hehongwei44/fd59dc215ad7d7e4fb41

  45. 判断传入的参数的长度是否在给定的有效范围内
  46. </>复制代码

    1. /**
    2. *
    3. * @description: 判断传入的参数的长度是否在给定的有效范围内
    4. * @param: minL->给定的最小的长度
    5. * @param: maxL->给定的最大的长度
    6. * @param: str->待验证的参数
    7. * @return : true表示合理,验证通过
    8. *
    9. */
    10. var isAvaiableLength = function(minL,maxL,str){
    11. return (str.length >= minL && str.length <= maxL) ? true : false;
    12. }
  47. 代码来源:https://gist.github.com/hehongwei44/005bf7f6836b3064c893

  48. 判断输入的参数是否是一个合格的身份证号码
  49. </>复制代码

    1. /**
    2. *
    3. * @descrition: 这个函数对输入的参数检查时候是合格的身份证号码,其身份证有效性无法判断。检测的颗粒度可以定制。
    4. * @param->str : 待验证的参数
    5. * @return : true是合格的身份证 false为不合法的身份证
    6. *
    7. */
    8. var checkIdCard = function (num) {
    9. num = num.toUpperCase();
    10. var cityCode = {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: "国外 "};
    11. if(!cityCode[num.substr(0,2)]){
    12. alert("地址编码错误");
    13. return false;
    14. }
    15. //身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X。
    16. if (!(/(^d{15}$)|(^d{17}([0-9]|X)$)/.test(num))) {
    17. //alert("输入的身份证号长度不对,或者号码不符合规定!
    18. 15位号码应全为数字,18位号码末位可以为数字或X。");
    19. return false;
    20. }
    21. //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
    22. //下面分别分析出生日期和校验位
    23. var len, re;
    24. len = num.length;
    25. if (len == 15) {
    26. re = new RegExp(/^(d{6})(d{2})(d{2})(d{2})(d{3})$/);
    27. var arrSplit = num.match(re);
    28. //检查生日日期是否正确
    29. var dtmBirth = new Date("19" + arrSplit[2] + "/" + arrSplit[3] + "/" + arrSplit[4]);
    30. var bGoodDay;
    31. bGoodDay = (dtmBirth.getYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) && (dtmBirth.getDate() == Number(arrSplit[4]));
    32. if (!bGoodDay) {
    33. //alert("输入的身份证号里出生日期不对!");
    34. return false;
    35. }
    36. else {
    37. //将15位身份证转成18位
    38. //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
    39. var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
    40. var arrCh = new Array("1", "0", "X", "9", "8", "7", "6", "5", "4", "3", "2");
    41. var nTemp = 0, k;
    42. num = num.substr(0, 6) + "19" + num.substr(6, num.length - 6);
    43. for (k = 0; k < 17; k++) {
    44. nTemp += num.substr(k, 1) * arrInt[k];
    45. }
    46. num += arrCh[nTemp % 11];
    47. return true;
    48. }
    49. }
    50. if (len == 18) {
    51. re = new RegExp(/^(d{6})(d{4})(d{2})(d{2})(d{3})([0-9]|X)$/);
    52. var arrSplit = num.match(re);
    53. //检查生日日期是否正确
    54. var dtmBirth = new Date(arrSplit[2] + "/" + arrSplit[3] + "/" + arrSplit[4]);
    55. var bGoodDay;
    56. bGoodDay = (dtmBirth.getFullYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) && (dtmBirth.getDate() == Number(arrSplit[4]));
    57. if (!bGoodDay) {
    58. //alert(dtmBirth.getYear());
    59. //alert(arrSplit[2]);
    60. //alert("输入的身份证号里出生日期不对!");
    61. return false;
    62. }
    63. else {
    64. //检验18位身份证的校验码是否正确。
    65. //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
    66. var valnum;
    67. var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
    68. var arrCh = new Array("1", "0", "X", "9", "8", "7", "6", "5", "4", "3", "2");
    69. var nTemp = 0, k;
    70. for (k = 0; k < 17; k++) {
    71. nTemp += num.substr(k, 1) * arrInt[k];
    72. }
    73. valnum = arrCh[nTemp % 11];
    74. if (valnum != num.substr(17, 1)) {
    75. //alert("18位身份证的校验码不正确!应该为:" + valnum);
    76. return false;
    77. }
    78. return true;
    79. }
    80. }
    81. return false;
    82. }
  50. 代码来源:https://gist.github.com/hehongwei44/808accd01e3c44f87f17

  51. 判断输入的参数是否为空
  52. </>复制代码

    1. /**
    2. *
    3. * @Dependence : https://gist.github.com/hehongwei44/3e167cfcda47d4c8051a#file-extendstringprototype-js
    4. * @description : 判断输入的参数是否为空
    5. * @return : true表示为输入参数为空
    6. *
    7. */
    8. var isEmpty = function (str) {
    9. //空引用 空字符串 空输入
    10. return str == null || typeof str == "undefined" || str.trim() == "" ? true : false;
    11. }
  53. 代码来源:https://gist.github.com/hehongwei44/1be8311320eb6f707394

  54. 判断输入的字符是否全部是中文字符
  55. </>复制代码

    1. /**
    2. *
    3. * @descrition: 测试给定的参数是否全部为中文字符,如"中test"不会通过 。
    4. * @param->str : 传入的参数,类型为字符串。
    5. * @return : true表示全部为中文,false为不全是中文,或没有中文。
    6. *
    7. */
    8. var isChinese = function (str) {
    9. var pattern = /^[u0391-uFFE5]+$/g;
    10. return pattern.test(str);
    11. }
  56. 代码来源:https://gist.github.com/hehongwei44/abeec850e6ff5134da9d

  57. 判断传入的参数是否为数字
  58. </>复制代码

    1. /**
    2. *
    3. * @descrition : 该函数的功能是判断转入的参数是否为数字类型。
    4. * @param->o : 传入的参数,参数可以为任何类型。
    5. * @return: true表示为数字,false为非数字
    6. *
    7. */
    8. var isNumber = function(o) {
    9. return !isNaN(o);
    10. }
  59. 代码来源:https://gist.github.com/hehongwei44/fca3f169ad547fc4ba5d

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/85488.html

相关文章

  • JavaScript常用脚本集锦3

    通过数组,拓展字符串拼接容易导致性能的问题 function StringBuffer() { this.__strings__ = new Array(); } StringBuffer.prototype.append = function (str) { this.__strings__.push(str); return this; } StringBuffer....

    dack 评论0 收藏0
  • JavaScript常用脚本集锦1

    摘要:初始化参数可选参数,必填参数可选,只有在请求时需要参数可选回调函数可选参数可选,默认为参数可选,默认为创建引擎对象打开发送普通文本接收文档将字符串转换为对象最后,说明一下此函数的用法。即等待与成功回调,后标志位置为。 jquery限制文本框只能输入数字 jquery限制文本框只能输入数字,兼容IE、chrome、FF(表现效果不一样),示例代码如下: $(input).keyup(...

    ygyooo 评论0 收藏0
  • JavaScript常用脚本集锦4

    摘要:一些元素位置设置的通用方法查找元素的左端位置代码依赖来自查找元素的顶端位置设置元素和位置与当前位置无关的一对函数设置元素水平的函数设置元素垂直位置的函数在元素的水平位置上增加像素距离的函数在元素的垂直位置上增加像素距离的函数代码来源元素相对 一些元素位置设置的通用方法 /** * 查找元素的左端位置, * 代码依赖:getStyle来自 https://gist.github.c...

    yeooo 评论0 收藏0
  • JavaScript常用脚本集锦2

    摘要:把中的伪数组转换为真数组在中,函数中的隐藏变量和用获得的元素集合都不是真正的数组,不能使用等方法,在有这种需要的时候只能先转换为真正的数组。检测元素是否支持某个属性代码用法创建和使用命名空间使用方式 把JavaScript中的伪数组转换为真数组 在 JavaScript 中, 函数中的隐藏变量 arguments 和用 getElementsByTagName 获得的元素集合(Nod...

    xialong 评论0 收藏0
  • JavaScript常用脚本集锦5

    摘要:代码来源一些常用的操作方法介绍查找相关元素的前一个兄弟元素的方法。查找元素指定层级的父元素。 DOM操作的增强版功能函数 /** * 将一个DOM节点、HTML字符串混合型参数 * 转化为原生的DOM节点数组 * * */ function checkElem(a) { var r = []; if (a.constructor != Array) { ...

    joywek 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<