JavaScript正则表达式

1.生成一个正则表达式regexObj

  • 描述字符串规则的表达式,两种方式
    • 直接量: /pattren/attrs(/规则/属性)
    • 对象构造方式:new RegExp(pattern,arrtes) (/规则/属性)

2.regexObj.test(str)

  • 测试正则表达式regexObj与指定字符串是否匹配
  1. /10086/.test('10086') //true
  2. /10086/.test('12314') //false
  3. /10086/.test('x10086s') //true //true
  • 由此看到.test()匹配了正则表达式,但是最后一条出来了一个问题。如果这种情况下/10086/.test('x10086s')正则表达式匹配到该字符串中确实含有此正则表达式
  • 所以必须要有一些限制,以下就是限制方法

锚点

  • 我们可以通过一个锚点匹配一个位置
    • ^:起始位置
    • $ :结尾位置
    • \b :单词边界
  1. //起始位置
  2. /^http:/.test('http://www.kejiganhuo.com') // true 以http:为起始的字符串可以匹配
  3. /^http:/.test('attp://www.kejiganhuo.com') // false
  4. /^http:/.test('https://www.kejiganhuo.com') //false
  5. //结尾位置
  6. /\.jpg$/.test('1.jpg') // true 以.jsp结尾的字符串可以匹配
  7. /\.jsp$/.test('1.jpg ls') // false
  8. //单词边界
  9. /\bis\b/.test('this is tyrmars') // true 这里is才是正则所匹配的,匹配的就是is,就是看有没有is字符串
  10. /\bis\b/.test('this') // false this是无法匹配单词边界为is
  11. /is\b/.test('this tyrmars') // true 这样就可以匹配,因为单词左边界没有限制
example1
  1. /^10086$/.test('10086') //true
  • 这种方法只能检测固定的号码,但是我们想检测同类的手机号码,所以就需要用到如下 字符类

字符类

  • 匹配一类字符中的一个,采用[],相当于限定字符集
    • [abc]:a或b或c
    • [0-9]:一个数字
    • [^0-9]:非数字的一个字符
    • [a-z]:一个字母
    • .:任意一个字符(除还行外)
  1. /[0-9]/.test(123) // true
  2. /[^1-9]/.test(0123) // false
  3. /[12345]/.test(0) // false
  4. /[abc]/.test('abcdefgh') //true
  5. /[abc]/.test('fgh') //false
example2
  1. /^1[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]$/.test(12345678901) //true
  • [0-9]可以被优化,所以学习到了元字符,元字符是具有特殊意义的字符

元字符

  • 具有特殊意义的字符
    • ^$\b
    • \d[0-9]
    • \D[^\d]
    • \s:空白符
    • \S[^\s]
    • \w[A-Z]
    • \W[^\w]
example3
  1. /^1\d\d\d\d\d\d\d\d\d\d\d$/.test(12345678901) //true
  • 不过呢,想一下这些\d都是重复的,所以需要用到量词

量词

  • 出现的次数
    • {m,n}:m到n次
    • *{0,} 出现0或n次
    • ?{0,1} 出现0或者1次
    • +{1,} 出现1或n次