(请参阅答案末尾的 ES2015 更新。)
您已将您的问题标记为string
和regex
。
在 JavaScript 中,反斜杠在字符串文字和正则表达式中都有特殊的含义。如果你想在字符串或正则表达式中使用实际的反斜杠,你必须写两个:\\
.
这个字符串以一个反斜杠开头,你在文字中看到的第一个是一个转义字符,告诉我们从字面上取下一个字符:
var str = "\\I have one backslash";
这个正则表达式匹配一个单个反斜杠(而不是两个); 同样,您在文字中看到的第一个是转义字符,告诉我们从字面上看下一个字符:
var rex = /\\/;
如果您使用字符串来创建正则表达式(而不是像我上面那样使用正则表达式文字),请注意您正在处理两个级别:字符串级别和正则表达式级别。因此,要使用匹配单个反斜杠的字符串创建正则表达式,您最终会使用四个:
var rex = new RegExp("\\\\");
那是因为首先,您正在编写一个字符串文字,但您想在其中实际放入反斜杠。所以你\\
对每一个你想要的反斜杠都这样做。但是您的正则表达式还需要\\
为您想要的每一个真正的反斜杠提供两个,因此它需要在字符串中看到两个反斜杠。因此,一共有四个。这是我new RegExp(string)
尽可能避免使用的原因之一;我很容易混淆。:-)
ES2015 和 ES2018 更新
快进到 2015 年,正如 Dolphin_Wood 指出的,新的 ES2015 标准为我们提供了模板文字、标签函数和String.raw
函数:
let str = String.raw`\apple`;
str
最终包含字符\
, a
, p
, p
, l
, 和e
。请注意${
您的“字符串”(模板)中没有,因为这是一个模板文字并${
开始替换。例如:
let foo = "bar";
let str = String.raw`\apple${foo}`;
...最终是\applebar
。更新:从 ES2018 开始,以下内容不再适用,它更新了模板文字以允许无效的转义序列,详情请点击此处。另请注意,这不太像C# 中的“逐字”字符串或类似的字符串,因为与规范中的LegacyOctalEscapeSequence匹配的序列是不允许的,并且会导致语法错误。所以例如
let str = String.raw`c:\foo\12\bar`;
...失败,因为它\12
看起来像一个传统的八进制文字。