JavaScript字符串换行符?

时间:2009-07-20 20:08:52

标签: javascript newline

{J}中所有平台的通用换行符都是\n吗?如果没有,我如何确定当前环境的字符?

我不是在询问HTML换行符元素(<BR/>)。我问的是JavaScript字符串中使用的换行符字符序列。

15 个答案:

答案 0 :(得分:347)

我刚刚使用这个愚蠢的JavaScript测试了一些浏览器:

function log_newline(msg, test_value) {
  if (!test_value) { 
    test_value = document.getElementById('test').value;
  }
  console.log(msg + ': ' + (test_value.match(/\r/) ? 'CR' : '')
              + ' ' + (test_value.match(/\n/) ? 'LF' : ''));
}

log_newline('HTML source');
log_newline('JS string', "foo\nbar");
log_newline('JS template literal', `bar
baz`);
<textarea id="test" name="test">

</textarea>

Windows上的IE8和Opera 9使用\r\n。我测试的所有其他浏览器(Windows上的Safari 4和Firefox 3.5以及Linux上的Firefox 3.0)都使用\n。设置值时,他们都可以正常处理\n,但IE和Opera会在内部再次将其转换回\r\n。这是一篇SitePoint文章,其中包含一些名为Line endings in Javascript的详细信息。

另请注意,这与HTML文件本身的实际行结尾无关(\n\r\n都会给出相同的结果)。

提交表单时,所有浏览器都会在URL编码中将新行标准化为%0D%0A。为了看到这一点,加载例如data:text/html,<form><textarea name="foo">foo%0abar</textarea><input type="submit"></form>并按提交按钮。 (某些浏览器阻止了已提交页面的加载,但您可以在控制台中看到URL编码的表单值。)

但是,我认为你真的不需要做任何决定。如果您只想在换行符上拆分文本,可以执行以下操作:

lines = foo.value.split(/\r\n|\r|\n/g);

答案 1 :(得分:80)

是的,这是普遍的。

虽然'\n'是通用的换行符字符,但您必须记住,根据您的输入,换行符前面可能会有回车符({{1} })。

答案 2 :(得分:57)

不要使用\ n,试试这个:

    var string = "this\
    is a multi\
    line\
    string";

只需输入反斜杠并继续卡车&#39;!像魅力一样。

答案 3 :(得分:49)

最简单的方法就是处理新行字符的所有情况,而不是检查应用它的情况。例如,如果您需要替换换行符,请执行以下操作:

htmlstring = stringContainingNewLines.replace(/(\r\n|\n|\r)/gm, "<br>");

答案 4 :(得分:22)

是使用\ n,除非您要生成html代码,否则您要使用<br />

答案 5 :(得分:13)

电子邮件链接功能我使用“%0D%0A”

function sendMail() {   
var bodydata="Before "+ "%0D%0A";
    bodydata+="After"

var MailMSG = "mailto:aaa@sss.com" 
         + "?cc=07@sss.com" 
         + "&subject=subject" 
         + "&body=" + bodydata; 
window.location.href = MailMSG; 
} 

[HTML]

<a href="#" onClick="sendMail()">Contact Us</a>

答案 6 :(得分:6)

获取当前浏览器的行分隔符:

function getLineSeparator() {
  var textarea = document.createElement("textarea");
  textarea.value = "\n"; 
  return textarea.value;
}

答案 7 :(得分:4)

注意事项 - 使用ExtendScript JavaScript(Photoshop CS3 +等应用程序中使用的Adobe Scripting语言)时,要使用的字符是“\ r”。 “\ n”将被解释为字体字符,因此许多字体将具有块字符。

例如(选择名为“Note”的图层并在所有句点后添加换行符):

var layerText = app.activeDocument.artLayers.getByName('Note').textItem.contents;
layerText = layerText.replace(/\. /g,".\r");

答案 8 :(得分:1)

我遇到了用 \ n \ r \ n 表示换行符的问题。
可悲的是,用于回车的字符 \ r 就像换行一样为我工作 所以在某些情况下,考虑\ r也是有用的。

答案 9 :(得分:1)

您可以在ES6中使用``引号(位于Esc按钮下方)。所以你可以这样写:

#ifdef useA
using C = CT<A>;
#else
using C = CT<B>;
#endif

答案 10 :(得分:0)

我相信它是 - 当你使用JS字符串时。

但是,如果要生成HTML,则必须使用<br />标记(而不是\n,因为您不再处理JS)

答案 11 :(得分:0)

实际观察...在我的NodeJS脚本中,我具有以下功能:

function writeToLogFile (message) {
    fs.appendFile('myserverlog.txt', Date() + " " + message + "\r\n", function (err) {
        if (err) throw err;
    });
}

首先,我只有“ \ n”,但是我注意到在记事本中打开日志文件时,它在同一行显示所有条目。另一方面,Notepad ++在各自的行上显示条目。将代码更改为“ \ r \ n”后,即使记事本也会在每行中显示每个条目。

答案 12 :(得分:-1)

casez

打印:

?

答案 13 :(得分:-3)

\n对我遇到的所有情况都很好。我正在使用网络,使用\n并且不用担心(除非您遇到任何与换行相关的问题)。

答案 14 :(得分:-11)

您可以使用<br/>document.write/document.writeln