Ich habe gerade einige Browser getestet, die dieses dumme JavaScript verwenden:
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>
IE8 und Opera 9 unter Windows verwenden \r\n
. Alle anderen von mir getesteten Browser (Safari 4 und Firefox 3.5 unter Windows und Firefox 3.0 unter Linux) verwenden \n
. Sie können alle mit \n
beim Einstellen des Wertes, obwohl IE und Opera diesen Wert wieder in \r\n
wieder innerlich. Es gibt einen SitePoint-Artikel mit einigen weiteren Details unter dem Titel Zeilenenden in Javascript .
Beachten Sie auch, dass dies unabhängig von den tatsächlichen Zeilenenden in der HTML-Datei selbst ist (beide \n
y \r\n
die gleichen Ergebnisse liefern).
Beim Absenden eines Formulars werden Zeilenumbrüche von allen Browsern kanonisiert zu %0D%0A
in URL-Kodierung. Um das zu sehen, laden Sie z.B. data:text/html,<form><textarea name="foo">foo%0abar</textarea><input type="submit"></form>
und drücken Sie die Schaltfläche Senden. (Einige Browser blockieren das Laden der übermittelten Seite, aber Sie können die URL-kodierten Formularwerte in der Konsole sehen).
Ich glaube aber nicht, dass Sie wirklich viel bestimmen müssen. Wenn Sie den Text nur an Zeilenumbrüchen trennen wollen, könnten Sie so vorgehen:
lines = foo.value.split(/\r\n|\r|\n/g);