我们首先来看如下代码,在浏览器中输出的是什么?
// 在浏览器中输出的
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
2. 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