JavaScript 正则表达式

1. JavaScript 正则表达式规则

| 符号 | 作用 | | —- | —- |

| \d | 数字(digital) |

| \D | 非数字 |

| \w | 单词(word):字母大写和小写,数字,下划线 |

| \W | 非单词 |

| \s | 空白字符(看不见的字符):空格、制表符(tab)、分页符、回车、换行 |

| \S | 非空白字符 |

| . | 通配符,任意字符,所以如果正则表达式中出现了”.”要转义”.” |

| {n} | 匹配n次个数 x = n次 |

| {n,} | 最少n次,x>=n |

| {n,m} | 在n和m之间,n<=x<=m |

| + | 1~n次 |

| * | 0~n次 |

| ? | 0~1次 |

| ^ | 匹配开头 |

| $ | 匹配结尾 |

2. 创建正则表达式的语法

在JS中正则表达式是一个对象:RegExp (Regular Expression 正则表达式)

2.1. 方式1

  • 语法:var reg = new RegExp("正则表达式","匹配模式");
  • 作用:直接创建一个正则表达式对象 ``` var reg = new RegExp(“\d{3}”);
  1. ### 2.2. 方式2
  2. - 语法:`var reg = /正则表达式/匹配模式;`

var reg = /\d{3}/;

  1. ### 2.3. 方式1和方式2的区别
  2. - 方式1中间是字符串,字符串`\`需要转义。
  3. - 方式2不是字符串,所以`\`不用转义,**建议使用方式2。(Java中没有这种写法)**
  4. ## 3. 正则表达式匹配
  5. ### 3.1. test() 匹配正则
  6. - 语法:`正则表达式对象.test("要匹配的字符串");`
  7. - 方法返回值:boolean类型的值
  8. - 作用:如果正则表达式匹配当前字符串返回true,否则返回false

// 例:test匹配函数 let testString = “My test string”; let testRegex = /string/; var result = testRegex.test(testString); // result为boolean类型

  1. ### 3.2. 匹配多个模式
  2. `|`:代表匹配多个不同的字符串

let testString = “no!” const regex = /yes|no|maybe/; var result = regex.test(testString); // true

  1. ### 3.3. 忽略大小写匹配
  2. - `i`:代表忽略大小写比较

/ 案例1 / // 写法1 var reg = new RegExp(“cat”, “i”); // 写法2 var reg = /cat/i; var b = reg.test(“CAT”); // b为true;

/ 案例2 / const caseInsensitiveRegex = /ignore case/i; const testString = ‘We use the i flag to iGnOrE CasE’; caseInsensitiveRegex.test(testString); // true

  1. ### 3.4. match() 提取变量的第一个匹配项
  2. - 语法:`需要匹配的字符串.match(正则表达式)`
  3. - 作用:返回字符串中第一个匹配正则的内容
  4. - 返回值:String

const match = “Hello World!”.match(/hello/i); // 返回字符串:”Hello”

  1. ### 3.5. 提取数组中的所有匹配项
  2. 标志符`g`:将字符串中匹配正则表达式的内容,以数组类型返回

const testString = “Repeat repeat rePeAT”; const regexWithAllMatches = /Repeat/gi; testString.match(regexWithAllMatches); // [“Repeat”, “repeat”, “rePeAT”]

  1. ### 3.6. 匹配任意字符
  2. - 使用通配符`.`作为任何字符的占位符

/ To match “cat”, “BAT”, “fAT”, “mat” const regexWithWildcard = /.at/gi; const testString = “cat BAT cupcake fAT mat dog”; const allMatchingWords = testString.match(regexWithWildcard); // [“cat”, “BAT”, “fAT”, “mat”] 用多种可能性匹配单个字符

  1. ### 3.7. 匹配一组字符
  2. 使用字符类,可以使用它来定义要匹配的一组字符,把它们放在方括号里`[]`

// 匹配 “cat” “fat” and “mat” 但不匹配 “bat” const regexWithCharClass = /[cfm]at/g; const testString = “cat fat bat mat”; const allMatchingWords = testString.match(regexWithCharClass); // [“cat”, “fat”, “mat”]

  1. ### 3.8. 匹配字母表中的字母
  2. 使用字符集内的范围 `[a-z]`

const regexWidthCharRange = /[a-e]at/; const regexWithCharRange = /[a-e]at/; const catString = “cat”; const batString = “bat”; const fatString = “fat”;

regexWithCharRange.test(catString); // true regexWithCharRange.test(batString); // true regexWithCharRange.test(fatString); // false

  1. ### 3.9. 匹配特定的数字和字母
  2. 使用连字符来匹配数字

const regexWithLetterAndNumberRange = /[a-z0-9]/ig; const testString = “Emma19382”; testString.match(regexWithLetterAndNumberRange) // true

  1. ### 3.10. 匹配单个未知字符
  2. 要匹配不想拥有的一组字符,使用否定字符集 `^`

const allCharsNotVowels = /[^aeiou]/gi; const allCharsNotVowelsOrNumbers = /[^aeiou0-9]/gi;

  1. ### 3.11. 匹配一行中出现一次或多次的字符
  2. 使用 `+` 标志

const oneOrMoreAsRegex = /a+/gi; const oneOrMoreSsRegex = /s+/gi; const cityInFlorida = “Tallahassee”;

cityInFlorida.match(oneOrMoreAsRegex); // [‘a’, ‘a’, ‘a’]; cityInFlorida.match(oneOrMoreSsRegex); // [‘ss’];

  1. ### 3.12. 匹配连续出现零次或多次的字符
  2. 使用星号 `*`

const zeroOrMoreOsRegex = /hi*/gi; const normalHi = “hi”; const happyHi = “hiiiiii”; const twoHis = “hiihii”; const bye = “bye”;

normalHi.match(zeroOrMoreOsRegex); // [“hi”] happyHi.match(zeroOrMoreOsRegex); // [“hiiiiii”] twoHis.match(zeroOrMoreOsRegex); // [“hii”, “hii”] bye.match(zeroOrMoreOsRegex); // null

  1. ### 3.13. 惰性匹配
  2. - 字符串中与给定要求匹配的最小部分
  3. - 默认情况下,正则表达式是贪婪的(匹配满足给定要求的字符串的最长部分)
  4. - 使用 `?` 阻止贪婪模式(惰性匹配)

const testString = “catastrophe”; const greedyRexex = /c[a-z]t/gi; const lazyRegex = /c[a-z]?t/gi;

testString.match(greedyRexex); // [“catast”] testString.match(lazyRegex); // [“cat”]

  1. ### 3.14. 匹配起始字符串模式
  2. 要测试字符串开头的字符匹配,请使用插入符号`^`,但要放大开头,不要放到字符集中

const emmaAtFrontOfString = “Emma likes cats a lot.”; const emmaNotAtFrontOfString = “The cats Emma likes are fluffy.”; const startingStringRegex = /^Emma/;

startingStringRegex.test(emmaAtFrontOfString); // true startingStringRegex.test(emmaNotAtFrontOfString); // false

  1. ### 3.15. 匹配结束字符串模式
  2. 使用 `$` 来判断字符串是否是以规定的字符结尾

const emmaAtBackOfString = “The cats do not like Emma”; const emmaNotAtBackOfString = “Emma loves the cats”; const startingStringRegex = /Emma$/;

startingStringRegex.test(emmaAtBackOfString); // true startingStringRegex.test(emmaNotAtBackOfString); // false

  1. ### 3.16. 匹配所有字母和数字
  2. 使用`\word`简写

const longHand = /[A-Za-z0-9_]+/; const shortHand = /\w+/; const numbers = “42”; const myFavoriteColor = “magenta”;

longHand.test(numbers); // true shortHand.test(numbers); // true longHand.test(myFavoriteColor); // true shortHand.test(myFavoriteColor); // true

  1. ### 3.17. 除了字母和数字,其他的都要匹配
  2. `\W` 表示 `\w` 的反义

const noAlphaNumericCharRegex = /\W/gi; const weirdCharacters = “!_$!!”; const alphaNumericCharacters = “ab283AD”;

noAlphaNumericCharRegex.test(weirdCharacters); // true noAlphaNumericCharRegex.test(alphaNumericCharacters); // false

  1. ### 3.18. 匹配所有数字
  2. 可以使用字符集`[0-9]`,或者使用简写`\d`

const digitsRegex = /\d/g; const stringWithDigits = “My cat eats $20.00 worth of food a week.”;

stringWithDigits.match(digitsRegex); // [“2”, “0”, “0”, “0”]

  1. ### 3.19. 匹配所有非数字
  2. `\D` 表示 `\d` 的反义

const nonDigitsRegex = /\D/g; const stringWithLetters = “101 degrees”;

stringWithLetters.match(nonDigitsRegex); // [“ “, “d”, “e”, “g”, “r”, “e”, “e”, “s”]

  1. ### 3.20. 匹配空格
  2. 使用 `\s` 来匹配空格和回车符

const sentenceWithWhitespace = “I like cats!”; var spaceRegex = /\s/g;

sentenceWithWhitespace.match(spaceRegex); // [“ “, “ “]

  1. ### 3.21. 匹配非空格
  2. `\S` 表示 `\s` 的反义

const sentenceWithWhitespace = “C a t” const nonWhiteSpaceRegex = /\S/g;

sentenceWithWhitespace.match(nonWhiteSpaceRegex); // [“C”, “a”, “t”]

  1. ### 3.22. 匹配的字符数
  2. 可以使用 `{下界,上界}` 指定一行中的特定字符数

const regularHi = “hi”; const mediocreHi = “hiii”; const superExcitedHey = “heeeeyyyyy!!!”; const excitedRegex = /hi{1,4}/;

excitedRegex.test(regularHi); // true excitedRegex.test(mediocreHi); // true excitedRegex.test(superExcitedHey); //false

  1. ### 3.23. 匹配最低个数的字符数
  2. 使用`{下界, }`定义最少数量的字符要求,下面示例表示字母 i 至少要出现2

const regularHi = “hi”; const mediocreHi = “hiii”; const superExcitedHey = “heeeeyyyyy!!!”; const excitedRegex = /hi{2,}/;

excitedRegex.test(regularHi); // false excitedRegex.test(mediocreHi); // true excitedRegex.test(superExcitedHey); //false

  1. ### 3.24. 匹配精确的字符数
  2. 使用`{requiredCount}`指定字符要求的确切数量

const regularHi = “hi”; const bestHi = “hii”; const mediocreHi = “hiii”; const excitedRegex = /hi{2}/;

excitedRegex.test(regularHi); // false excitedRegex.test(bestHi); // true excitedRegex.test(mediocreHi); //false

  1. ### 3.25. 匹配0次或1次
  2. 使用 `?` 匹配字符 0 次或1

const britishSpelling = “colour”; const americanSpelling = “Color”; const languageRegex = /colou?r/i;

languageRegex.test(britishSpelling); // true languageRegex.test(americanSpelling); // true

  1. ## 4. 匹配上与Java中的不同
  2. **Java在默认的情况下是精确匹配,在JS中默认是模糊匹配**,只要**包含**正则表达式中的字符串就返回true
  3. |
  4. **正则表达式**
  5. | **匹配字符串**
  6. | **Java中匹配结果**
  7. | **JavaScript中匹配结果**
  8. | **说明**
  9. |
  10. | --- | --- | --- | --- | --- |
  11. |
  12. `/\d{3}/`
  13. | a123b
  14. | false
  15. | true
  16. | 只要包含3个数字即可
  17. |
  18. |
  19. `/^\d{3}/`
  20. | 123b
  21. | false
  22. | true
  23. | 3个数字开头
  24. |
  25. |
  26. `/\d{3}$/`
  27. | a123
  28. | false
  29. | true
  30. | 3个数字结尾
  31. |
  32. |
  33. `/^\d{3}$/`
  34. | 123
  35. | true
  36. | true
  37. | 只能匹配3个数字
  38. |
  39. **_注:如果想完全匹配就`^$`包括起来_**
  40. ## 5. 正则表达式案例
  41. ### 5.1. 一个正则表达式案例(练习)
  42. ![](https://gitee.com/moonzero/images/raw/master/code-note/20190515103801802_5650.jpg)
  43. - 需求:用户注册,需要进行如下验证,请在JS中使用正则表达式进行验证。
  44. 1. 用户名:只能由英文字母和数字组成,长度为416个字符,并且以英文字母开头
  45. 1. 密码:大小写字母和数字6-20个字符
  46. 1. 确认密码:两次密码要相同
  47. 1. 电子邮箱:符合邮箱地址的格式`/^\w+@\w+(\.[a-zA-Z]{2,3}){1,2}$/`
  48. 1. 手机号:`/^1[34578]\d{9}$/`
  49. 1. 生日:生日的年份在19002009之间,生日格式为1980-5-121988-05-04的形式,`/^((19\d{2})|(200\d))-(0?[1-9]|1[0-2])-(0?[1-9]|[1-2]\d|3[0-1])$/`
  50. - Code Demo:正则表达式验证用户输入信息案例部分,全部常见Day32LessonDemo

// 验证所有注册项是否正确,再提交 function checkAll(){ return checkUser() && checkPassword() && doubleCheckPwd() && checkEmail() && checkMobile() && checkBirth(); }

// 验证用户名是否正确 function checkUser(){ // 创建验证的正则表达式 // 只能由英文字母和数字组成,长度为4~16个字符,并且以英文字母开头 var reg = /^[a-zA-Z][a-zA-Z0-9]{3,15}$/;

  1. // 获取文本框的值
  2. var user = document.getElementById("user").value;
  3. // 比较文本内容是否正确
  4. if(reg.test(user)){
  5. // 正确则显示勾,并返回true
  6. document.getElementById("userInfo").innerHTML = "<img src='../img/注册验证/img/gou.png' width='15'/>";
  7. return true;
  8. }else{
  9. // 错误则显示错误提示,并返回false
  10. document.getElementById("userInfo").innerHTML = "用户名格式不正确";
  11. return false;
  12. }

}

  1. ### 5.2. 取值范围为0-999.99的JS正则表达式

var reg = /^([1-9]\d{2})|([1-9]\d{1})|\d(.\d{1,2})?$/;

  1. ### 5.3. 手机号码

$(document).ready(function(){ //判断输入手机号码是否正确 $(“#telephone”).focus(function(){ document.getElementById(“ph-hint”).innerHTML = “:open_mouth:请输入11位手机号码”;

}) $(“#telephone”).blur(function(){ if(/^((13[0-9])|(15[^4,\D])|(18[0-9]))\d{8}$/.test(this.value)){ document.getElementById(“ph-hint”).innerHTML = “”; }else if(document.getElementById(“telephone”).value == “”){ document.getElementById(“ph-hint”).innerHTML = “ 咦,手机号不能为空哦”; }else{ document.getElementById(“ph-hint”).innerHTML = “ 这好像不是一个手机号码哦”; document.getElementById(“telephone”).value = “”; } }) })

  1. 详解:当获取焦点时,提示文字请输入手机号,然后失去焦点时判断,那段正则表达式表示的是13几,这个几0-9都可以,或者15几,但是非4的都行,或者18几,0-9都可以,然后再加8位数字,符合条件则成功,否则根据情况判断提示文字;
  2. ### 5.4. 密码

$(document).ready(function(){ //判断输入密码格式是否正确 $(“#setpassword”).focus(function(){ document.getElementById(“pw-hint”).innerHTML = “:open_mouth:请您输入密码,6-15个字母数字和符号两种以上组合”;

}) $(“#setpassword”).blur(function(){ if(/^(?![0-9]+$)(?![a-z]+$)(?![A-Z]+$)(?![,.#%’+*-:;^`]+$)[,.#%’+*-:;^`0-9A-Za-z]{6,15}$/.test(this.value)){ document.getElementById(“pw-hint”).innerHTML = “”; }else if(document.getElementById(“setpassword”).value == “”){ document.getElementById(“pw-hint”).innerHTML = “ 咦,密码不能为空哦”; }else{ document.getElementById(“pw-hint”).innerHTML = “ 你的密码格式有误,请重新输入”; document.getElementById(“setpassword”).value = “”; } }) })

  1. 详解:当获取焦点时,提示文字请输入密码,然后失去焦点时判断,那段正则表达式表示的是可以输入0-9的数字和大小写的字母a-z,外加一些特殊符号,然后可以输入6-15位密码,符合条件则成功,否则根据情况判断提示文字;<br />以下格式我就不这样写了,简介一点,上面两段可以去参考。
  2. ### 5.5. 用户名

//用户名正则,4到16位(字母,数字,下划线,减号) var username = /^[a-zA-Z0-9_-]{4,16}$/; //文字 var username=/[\d]/g;

  1. ### 5.6. 电子邮箱

//对电子邮件的验证 var email = /^([a-zA-Z0-9]+[|\|.]?)[a-zA-Z0-9]+@([a-zA-Z0-9]+[|\|.]?)[a-zA-Z0-9]+.[a-zA-Z]{2,3}$/;

  1. ### 5.7. 身份证号

//身份证号(18位)正则 var cP = /^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/;

  1. ### 5.8. 日期

//日期正则,简单判定,未做月份及日期的判定 var time = /^\d{4}(-)\d{1,2}\1\d{1,2}$/; //日期正则,复杂判定 var time = /^(?:(?!0000)[0-9]{4}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-8])|(?:0[13-9]|1[0-2])-(?:29|30)|(?:0[13578]|1[02])-31)|(?:[0-9]{2}(?:0[48]|[2468][048]|[13579][26])|(?:0[48]|[2468][048]|[13579][26])00)-02-29)$/;

  1. ### 5.9. QQ号以及微信号

//QQ号正则,5至11位 var qq = /^[1-9][0-9]{4,10}$/; //微信号正则,6至20位,以字母开头,字母,数字,减号,下划线 var wx = /^a-zA-Z+$/;

  1. ### 5.10. 座机号

//座机号 var tel =/(^0\d{2}-8\d{7}$)|(^0\d{3}-3\d{6}$)/;

  1. 附加: 发送验证码倒计时写法

//登录,忘记密码的验证码 var counts = 60; function settime(val) { if (counts == 0) { val.removeAttribute(“disabled”); val.value = “获取验证码”; counts = 60; return false; } else { val.setAttribute(“disabled”, true); val.value = “重新发送(“+counts+”)”; counts—; } setTimeout(function () { settime(val); }, 1000); }

```