Es sieht so aus, als würde Regex /\r\n|\r|\n/
die Zeilenenden CR, LF und CRLF, ihre gemischten Sequenzen, behandeln und alle leeren Zeilen dazwischen behalten. Versuch das!
function splitLines(t) { return t.split(/\r\n|\r|\n/); }
// single newlines
splitLines("AAA\rBBB\nCCC\r\nDDD");
// double newlines
splitLines("EEE\r\rFFF\n\nGGG\r\n\r\nHHH");
// mixed sequences
splitLines("III\n\r\nJJJ\r\r\nKKK\r\n\nLLL\r\n\rMMM");
Sie sollten diese Arrays als Ergebnis erhalten:
[ "AAA", "BBB", "CCC", "DDD" ]
[ "EEE", "", "FFF", "", "GGG", "", "HHH" ]
[ "III", "", "JJJ", "", "KKK", "", "LLL", "", "MMM" ]
Sie können diesem regulären Ausdruck auch beibringen, andere legitime Unicode-Zeilenendezeichen zu erkennen, indem Sie |\xHH
oder |\uHHHH
Teile hinzufügen , wobei H
es sich um hexadezimale Ziffern des zusätzlichen Codezeichens für Abschlusszeichen handelt (siehe Wikipedia-Artikel als U+HHHH
).