美文网首页
开发常用js方法

开发常用js方法

作者: 夏晶晶绿 | 来源:发表于2019-10-24 09:58 被阅读0次
  • js不区分大小写匹配并代码高亮,且不改变原来文本大小写格式
function heightLight(string, keyword) {
   var reg = new RegExp(keyword, "gi");
      string = string.replace(reg, function(txt){
      return "<i>"+txt+"</i>";
  })
  return string;
}
  • 身份证验证
identityIDCard(code) {
      // 身份证号前两位代表区域
      var city = {
        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 idCardReg = /^\d{6}(18|19|20)?\d{2}(0[1-9]|1[012])(0[1-9]|[12]\d|3[01])\d{3}(\d|X)$/i
      var isPass = true// 身份证验证是否通过(true通过、false未通过)

      // 如果身份证不满足格式正则表达式
      if (!code || !idCardReg.test(code)) {
        isPass = false
      } else if (!city[code.substr(0, 2)]) { // 区域数组中不包含需验证的身份证前两位
        isPass = false
      } else { // 18位身份证需要验证最后一位校验位
        if (code.length == 18) {
          code = code.split('')
          // ∑(ai×Wi)(mod 11)
          // 加权因子
          var factor = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
          // 校验位
          var parity = [1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2]
          var sum = 0
          var ai = 0
          var wi = 0
          for (var i = 0; i < 17; i++) {
            ai = code[i]
            wi = factor[i]
            sum += ai * wi
          }
          var last = parity[sum % 11]
          if (last != code[17]) {
            isPass = false
          }
        }
      }
      return isPass
    },
  • 校验车牌
function isCarNum(val) {
        var patrn = /^([京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领A-Z]{1}[A-Z]{1}[A-HJ-NP-Z0-9]{4}[A-HJ-NP-Z0-9挂学警港澳]{1})$/
        var patrn2 = /^([京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领A-Z]{1}[A-Z]{1}(([0-9]{5}[DF])|([DF]([A-HJ-NP-Z0-9])[0-9]{4})))$/
        if (!patrn.test(val) && !patrn2.test(val)) {
          return false
        } else {
          return true
        }
 }

  • 单个或者多个逗号分割验证
//验证aaaa或者aaaa,bbbb,cccc
var reg=/^([a-zA-Z]{4},)*([a-zA-Z]{4})$/g
  • ip验证正则
/^((2[0-4]\d|25[0-5]|[01]?\d\d?)\.){3}(2[0-4]\d|25[0-5]|[01]?\d\d?)$/
  • 字符串金额,整数或小数点后最多两位
/^(\d*|\d*[\.]\d{0,2})$/
  • 10位金额,小数点后最多两位
/^(\d{0,10}|\d{0,10}[\.]\d{0,2})$/
  • 替换开头的多余0为空
replace(/^0+(?=\d)/,'')
  • 字符串中间替换为同样个数星号
// 12位及以上前后显示4位,6到11位及以上前后显示2位,小于6位不用替换
function middleStar(val) {
    var html = ''
    if(typeof val==='string'){
        if(val.length>=12){
            html =val.replace(/(?<=.{4}).(?=.{4})/g,"*")
        }else if(val.length>=6){
            html =val.replace(/(?<=.{2}).(?=.{2})/g,"*")
        }else{
            html = val
        }
    }else{
        html = val
    }
    return html
}

相关文章

  • 开发常用js方法

    1.js不区分大小写匹配并代码高亮,且不改变原来文本大小写格式 2.身份证验证 3.校验车牌 4.单个或者多个逗号...

  • Javascript第四章内置函数、函数的基本用法第一课

    js的内置对象是js自带,封装了一些常用的方法,供开发者使用,可以无需创建对象直接使用。常用的js内置对象有:St...

  • Vue.js开发常见问题解析

    此前的Vue.js系列文章: Vue.js常用开发知识简要入门(一) Vue.js常用开发知识简要入门(二) Vu...

  • JavaScript数组常用方法

    目录 JS 数组常用API常用属性常用方法常见方法语法解释from方法isArrayconcateveryfill...

  • beta——js通用工具库

    背景:针对业务需要,对js常用方法进行整合,提升开发效率github地址:https://github.com/x...

  • js基础了解

    js数组常用遍历方法使用: js数组常用操作方法使用: 基本逻辑运算: 基本字符串操作方法:

  • vue axios cdn 封装

    1.config.js 常用域名封装: 2.utils.js 常用的方法封装: 3.api.js axios接口...

  • 2016-08-05学习笔记

    JS简介 循环 方法一:if goto 常用 方法二:while 常用 方法三:for 常用 同一个变量不能申明...

  • JsUtil

    一些常用的JS方法

  • js 常用方法总结

    字符串的常用属性,概览 Array对象的方法; 详细js数组常用方法大全

网友评论

      本文标题:开发常用js方法

      本文链接:https://www.haomeiwen.com/subject/cdkrvctx.html