1、创建对象

    1. var reg = /xinlang/;
    2. var str = 'xinlangasdfasdf';
    3. // 检验字符串是否匹配正则表达式,用test
    4. var boo = reg.test(str);
    5. console.log('boo', boo); // true
    6. // 2.方式2: 使用构造函数方式创建正则对象
    7. var reg2 = new RegExp('zhanghuan');
    8. var str = 'asdfasdfzhanghuanasdfasdf';
    9. var boo2 = reg2.test(str);
    10. console.log('boo2', boo2); //
    11. // 3.正则表达式参数g-全局匹配,i-忽略大小写,m-多行匹配
    12. var reg3 = /zhanGsan/gi;
    13. // var reg3 = new RegExp('zhangsan','g');
    14. var str3 = '111111111zhangsan222222zhangsan333333zhangsan';
    15. var newStr3 = str3.replace(reg3, '张三');
    16. console.log('newStr3', newStr3);

    2、常见匹配规则

    1. var log = function() {
    2. var len = arguments.length;
    3. if (len === 1) {
    4. console.log(arguments[0])
    5. } else if (len === 2) {
    6. console.log(arguments[0], arguments[1]);
    7. } else {
    8. console.log(arguments[0], arguments[1], arguments[2]);
    9. }
    10. console.log('')
    11. }
    12. // 1. 任意字符 .
    13. var reg1 = /.../;
    14. var str1 = 'aa';
    15. console.log('boo1', reg1.test(str1)); // false
    16. // 2. \w 字母、数字、下划线
    17. var reg2 = /\w\w/;
    18. var str2 = 'as';
    19. console.log('boo2', reg2.test(str2)); // true
    20. console.log('boo2', reg2.test('$a')); // false
    21. // 3. \s 任意空白字符
    22. var reg3 = /..\s../;
    23. console.log('boo3', reg3.test('aa bb')); // true
    24. console.log('boo3', reg3.test('aa bb')); // true
    25. // 4. \d 匹配数字,等同于[0-9]
    26. var reg4 = /\d\d\d\d/;
    27. console.log('boo4', reg4.test('9999')); // true
    28. // 5. \D 匹配非数字,等同于\[^0-9]
    29. var reg5 = /\d\D\d/;
    30. console.log('boo5', reg5.test('233')); // false
    31. console.log('boo5', reg5.test('2a3')); // true
    32. // 6. | 或匹配,如 /x|y/ 正则可匹配 x 或 y 两个字符
    33. var reg6 = /abc|xyz/;
    34. console.log('boo6', reg6.test('asdfasdfabcasdfasdf')); // true
    35. console.log('boo6', reg6.test('asdfasdfxyzasdfasdf')); // true
    36. // 7. [xyz] 表示包含 xyz 里面的任意一个,相当于x|y|z
    37. var reg7 = /[abc]/;
    38. log('boo7', reg7.test('aaa')); // true
    39. log('boo7', reg7.test('ddd')); // false
    40. // [a-zA-Z] // 匹配所有的大小写字母
    41. var reg7 = /[a-zA-Z]/;
    42. var reg7 = /[0-9]/; // 匹配0到9,相当于\d
    43. // 8. [^x] 匹配除“x”之外的所有字符,其中“x”可以为任意字符
    44. var reg8 = /[^s]/;
    45. log('boo8', reg8.test('asdf')); // true
    46. log('boo8', reg8.test('sss')); // false
    47. // 9. [^xyz] 同上,匹配除“x、y、z”之外的任意字符
    48. var reg9 = /[^abc]/; // 存在abc以外的字符都能匹配
    49. log('boo9', reg9.test('d')); // true
    50. log('boo9', reg9.test('ab')); // false
    51. // 10. ^ 匹配字符串的开始
    52. var reg10 = /^[a-zA-Z]\w\w\w/; // 匹配:第一个字符是字母,紧跟三个字符(数字,字母或下划线)
    53. log('boo10', reg10.test('a_8al2k323')); // true
    54. log('boo10', reg10.test('8a_8al2k323')); // false
    55. var reg10 = /^1\d\d\d\d\d\d\d\d\d\d$/; // 11位数字
    56. log('boo10', reg10.test('13811111111')); // true
    57. log('boo10', reg10.test('23811111111')); // false
    58. // 11. \$ 匹配字符串的结束
    59. // 12. \x 转义字符
    60. var reg12 = /\.com/;
    61. log('boo12', reg12.test('acom')); // false
    62. log('boo12', reg12.test('asdfasdf.com')); // true
    63. // '2021/05/05'
    64. var reg12 = /\d\d\d\d\/\d\d\/\d\d/;
    65. // 13. `?` 重复出现零次或一次
    66. var reg13 = /^https?/;
    67. console.log('boo13', reg13.test('http://asdfasdfasdf')); // true
    68. console.log('boo13', reg13.test('https://asdfasdfasdf')); // true
    69. // 14. `+` 重复出现一次或多次
    70. var reg14 = /a+/; // 有一个a或者多个a都能匹配
    71. log('boo14', reg14.test('sdfsdfsaasdf')); // true
    72. log('boo14', reg14.test('22222a')); // true
    73. // 15. `*` 重复出现零次或多次
    74. var reg15 = /^https?.*/;
    75. log('boo15', reg15.test('http://asdfasdfsadf')); // true
    76. // 16. {n} 重复出现 n 次
    77. var reg16 = /^1\d{10}$/;
    78. // 17. {n,} 至少重复出现 n 次
    79. var reg17 = /\d{10,}/; // 至少有10个数字
    80. // 18. {m,n} 重复重现 m 到 n 次,其中,m<n
    81. var reg17 = /\d{10,20}/; // 匹配10个到20个数字

    3、惰性匹配

    1. var reg = /\d+/;
    2. var str = '23423424234234234';
    3. var arr = str.match(reg);
    4. console.log('arr', arr);
    5. var reg2 = /\d+?/;
    6. var arr2 = str.match(reg2);
    7. console.log('arr2', arr2);

    4、分组

    1. // 分组可以使用 \1-代表第一组, \2-第2组
    2. var dateReg1 = /^(\d{4})-(\d{2})-(\d{2})$/;
    3. var dateReg2 = /^(\d{4})-(\d{2})-\2$/; // \d{2} 和 \2 数字要一样
    4. var str = '2021-06-06';
    5. console.log('date1', dateReg1.test(str));
    6. console.log('date2', dateReg2.test(str));
    7. var phoneReg = /^(1\d{2})(\d{4})\2$/;
    8. var str = '13800000000';
    9. console.log('phone', phoneReg.test(str));
    10. // 字符串替换时,可以使用正则分组,使用$1-第1组,$2-表示第2组
    11. var str = '13811112222';
    12. var newStr = str.replace(/(\d{3})(\d{4})(\d{4})/, '$1****$3');
    13. console.log('newStr', newStr);
    1. // 字面量的方式创建对象
    2. var obj = {
    3. a: 2,
    4. b: 3
    5. };
    6. // 构造函数方式创建对象,构造函数是用来创建对象
    7. var obj1 = new Object();
    8. obj1.name = 'zhangsan';
    9. // 字面量
    10. var arr = [1, 2, 3];
    11. // 构造函数
    12. var arr1 = new Array();
    13. arr1[0] = 1;
    14. arr1[1] = 2;
    1. function add() {
    2. console.log(arguments[0], arguments[1]);
    3. }
    4. add(10, 20);
    5. var log = function() {
    6. var len = arguments.length;
    7. if (len === 1) {
    8. console.log(arguments[0])
    9. } else if (len === 2) {
    10. console.log(arguments[0], arguments[1]);
    11. } else {
    12. console.log(arguments[0], arguments[1], arguments[2]);
    13. }
    14. }
    15. log(1);
    16. log(1, 2);
    17. log(1, 2, 3);