Схоже, регулярні вирази /\r\n|\r|\n/обробляють закінчення рядків CR, LF та CRLF, їх змішані послідовності, і зберігають між собою всі порожні рядки. Спробуйте це!
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");
Ви отримаєте ці масиви в результаті:
[ "AAA", "BBB", "CCC", "DDD" ]
[ "EEE", "", "FFF", "", "GGG", "", "HHH" ]
[ "III", "", "JJJ", "", "KKK", "", "LLL", "", "MMM" ]
Ви також можете навчити цей регулярний вираз розпізнавати інші легітимні термінатори Unicode , додавши |\xHHабо |\uHHHHчастини, де H- це шістнадцяткові цифри кодової точки додаткового символу термінатора (як видно в статті Вікіпедії як U+HHHH).