美文网首页
2023-02-21 JS正则关于多个反斜杠的含义

2023-02-21 JS正则关于多个反斜杠的含义

作者: 追寻1989 | 来源:发表于2023-02-20 17:50 被阅读0次

    我们首先来看如下代码,在浏览器中输出的是什么?

    // 在浏览器中输出的
    console.log('\\'); // 输出 \
    console.log('\\\\'); // 输出 \\
    
    一:js正则直接量语法对 反斜杠的含义
    1.1 \. 一个反斜杠加点号(.)
    var reg1 = /^\.$/g; 
    console.log(reg1.test('.')); // 输出 true, 因为 \. 是对元字符.进行转义,因此匹配字符串中的.
    console.log(reg1.test('a')); // 输出false \. 转义后只能匹配字符串中的. ,不再是元字符匹配任意单个字符了
    
    1.2 \\. 两个反斜杠加 (.)

    在js正则表达式中,两个反斜杠加点号(.), 两个反斜杠会原样输出 \ 字符串。元字符 . 匹配任意字符。

    var reg2 = /^\\.$/g; 
    console.log(reg2.test('\a')); // false
    console.log(reg2.test('\\a')); // true
    console.log(reg2.test('a')); // false
    console.log(reg2.test('\\ab')); // false
    console.log(reg2.test('\\.')); // true
    
    1.3 \\\. 三个反斜杠和点号(.)

    在js正则表达式中,三个反斜杠和 . ,前两个反斜杠匹配两个反斜杠,后面的 . 是对元字符.号进行转义,因此只能匹配字符串中的 . 号,不能匹配任意一个字符。

    var reg3 = /^\\\.$/g; 
    console.log(reg3.test('\a')); // false
    console.log(reg3.test('\\.')); // true
    console.log(reg3.test('a')); // false
    console.log(reg3.test('\\a')); // false
    
    1.4 \\\\. 四个反斜杠加点号(.)

    在js正则表达式中,四个反斜杠匹配四个反斜杠,然后后面的点号是匹配任意的字符,除点之外。

    var reg4 = /^\\\\.$/g;
    
    console.log(reg4.test('\\a')); // false
    console.log(reg4.test('\\\.')); // false
    console.log(reg4.test('\\\a')); // false
    console.log(reg4.test('\\\\a')); // true
    console.log(reg4.test('\\\\.')); // false
    console.log(reg4.test('\\aa')); // false
    
    二:JS中RegExp对象对反斜杠的含义
    2.1 \\. 两个反斜杠加点号(.)

    两个反斜杠加点的含义是:全局匹配字符串中带有点号的。找到的话,就返回true,否则的话,返回false, 首先两个反斜杠在正则 RegExp,返回一个反斜杠 .

    因此一个 反斜杠 . 就是对元字符 . 进行转义。因此只能匹配 . 号了。
    如下代码:

    var reg11 = new RegExp('\\.', 'g');
    
    console.log(reg11); // 输出 /\./g
    
    console.log(reg11.test('.')); // true
    console.log(reg11.test('\.')); // false
    console.log(reg11.test('\a')); // false
    console.log(reg11.test('.a')); // true
    console.log(reg11.test('n.a')); // true
    
    2.2 \\\. 三个反斜杠加点号(.)

    三个反斜杠和两个反斜杠的含义一样的。

    var reg12 = new RegExp('\\\.', 'g');
    
    console.log(reg12); // 输出 /\./g
    console.log(reg12.test('.')); // true
    console.log(reg12.test('\.')); // false
    console.log(reg12.test('\a')); // false
    console.log(reg12.test('.a')); // true
    console.log(reg12.test('n.a')); // true
    
    2.3 \\\\. 四个反斜杠加点号(.)

    四个反斜杠加点号的含义是:在RegExp对象后,会返回 /\\./g 然后是匹配字符串 \\, 点号(.) 是元字符匹配任意的字符。

    var reg12 = new RegExp('\\\\.', 'g');
    
    console.log(reg12); // 输出 /\\./g
    console.log(reg12.test('.')); // false
    console.log(reg12.test('\.')); // false
    console.log(reg12.test('\a')); // false
    console.log(reg12.test('.a')); // false
    console.log(reg12.test('n.a')); // false
    
    console.log(reg12.test('\\a')); // true
    console.log(reg12.test('\\aaaa')); // false
    
    console.log(reg12.test('\\.')); // true
    

    相关文章

      网友评论

          本文标题:2023-02-21 JS正则关于多个反斜杠的含义

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