在JavaScript中是否有一个字符来分解代码行,以便尽管它在新的行上,它仍然被视为连续的?
之类的……
1. alert ( "Please Select file 2. \ to delete" );
在JavaScript中是否有一个字符来分解代码行,以便尽管它在新的行上,它仍然被视为连续的?
之类的……
1. alert ( "Please Select file 2. \ to delete" );
当前回答
您可以将长字符串常量分解为逻辑块并将它们分配到数组中。然后使用空字符串作为分隔符进行连接。
var stringArray = [
'1. This is first part....',
'2. This is second part.....',
'3. Finishing here.'
];
var bigLongString = stringArray.join('');
console.log(bigLongString);
输出将是:
这是第一部分....。这是第二部分.....3。完成。
这种方式对性能有轻微的影响,但在代码可读性和可维护性方面有所收获。
其他回答
在你的例子中,你可以把字符串分成两部分:
alert ( "Please Select file"
+ " to delete");
或者,当它是一个字符串,就像在你的情况下,你可以使用@Gumbo建议的反斜杠:
alert ( "Please Select file\
to delete");
注意,这种反斜杠方法不一定是首选的,也可能不是普遍支持的(我很难找到关于这方面的硬数据)。它不在ECMA 5.1规范中。
当处理其他代码(不加引号)时,换行符将被忽略,这是完全可以接受的。例如:
if(SuperLongConditionWhyIsThisSoLong
&& SuperLongConditionOnAnotherLine
&& SuperLongConditionOnThirdLineSheesh)
{
// launch_missiles();
}
把反斜杠放在行末:
alert("Please Select file\
to delete");
我必须指出,这不是ECMAScript字符串的一部分,因为行结束字符是不允许的:
'LineTerminator'字符不能出现在字符串文本中,即使前面有反斜杠\。使行结束符成为字符串字面值字符串值的一部分的正确方法是使用转义序列,例如\n或\u000A。
所以使用字符串连接是更好的选择。
ECMAScript5中的字符串字面量允许上述语法:
行结束符不能出现在字符串文字中,除非作为LineContinuation的一部分以产生空字符序列。使行结束符成为字符串字面量String值的一部分的正确方法是使用转义序列,例如\n或\u000A。
ECMAScript 6引入了模板字符串:
模板字符串是允许嵌入表达式的字符串字面量。 可以使用多行字符串和字符串插值功能 他们。
例如:
alert(`Please Select file
to delete`);
警告:
Please Select file
to delete
对于VSCode用户来说,这是一个很好的解决方案,如果字符串分解成多行导致问题(当我不得不测试一个很长的JWT令牌时,我就遇到过这个问题,不知为何使用模板字面量没有做到这一点)。
我尝试了上面的一些建议,但在Chrome代码检查器中得到了一个非法字符警告。下面的方法对我来说是有效的(不过只在Chrome中测试过!)
alert('stuff on line 1\\nstuff on line 2);
就像…
stuff on line 1
stuff on line 2
注意双反斜杠!!…这似乎很重要!