Il ressemble à regex /\r\n|\r|\n/gère les fins de ligne CR, LF et CRLF, leurs séquences mixtes, et garde toutes les lignes vides entre elles. Essayez ça!
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");
Vous devriez obtenir ces tableaux en conséquence:
[ "AAA", "BBB", "CCC", "DDD" ]
[ "EEE", "", "FFF", "", "GGG", "", "HHH" ]
[ "III", "", "JJJ", "", "KKK", "", "LLL", "", "MMM" ]
Vous pouvez également apprendre à cette regex à reconnaître d'autres terminateurs de ligne Unicode légitimes en ajoutant |\xHHou |\uHHHHparts, où Hsont les chiffres hexadécimaux du point de code du caractère de terminaison supplémentaire (comme vu dans l'article de Wikipedia sous U+HHHH).