String.prototype.split()
Метод split()
(розщепити) значень String
приймає патерн і ділить свій рядок на впорядкований список підрядків шляхом пошуку переданого патерну, додання підрядків до масиву і повернення цього масиву.
Спробуйте його в дії
Синтаксис
split(separator)
split(separator, limit)
Параметри
separator
(розділювач) Необов'язковеПатерн, що вказує, де повинно відбутися кожне розщеплення. Може бути або
undefined
, або рядком, або об'єктом з методомSymbol.split
; типовим прикладом такого об'єкта є регулярний вираз. Пропускseparator
чи передача в ньомуundefined
призводить до того, щоsplit()
повертає масив, єдиним елементом якого є вихідний рядок. Усі значення, котрі не є аніundefined
, ані об'єктами з методом[Symbol.split]()
, зводяться до рядків.limit
(обмеження) Необов'язковеНевід'ємне ціле число, котре позначає обмеження кількості підрядків, які буде включено в повернений масив. Якщо цей параметр задано, рядок розділяється в кожному місці, де трапляється вказаний
separator
, проте зупиняється, коли в масиві опиняється вказана вlimit
кількість елементів. Будь-який залишок тексту не буде включено в масив узагалі.- Масив може містити менше елементів, ніж вказано в
limit
, якщо функція дійшла до кінця рядка раніше, ніж був вибранийlimit
. - Якщо
limit
дорівнює0
, буде повернено[]
.
- Масив може містити менше елементів, ніж вказано в
Повернене значення
Масив
рядків, розділених в місцях, де в початковому рядку знаходилися значення розділювача separator
.
Опис
Якщо separator
– непустий рядок, то цільовий рядок ділиться за всіма входженнями separator
, не включаючи separator
в результати. Наприклад, рядок, що містить розділені табуляцією значення (TSV) може бути розібраний шляхом передачі символу табуляції як розділювача: myString.split("\t")
. Якщо separator
містить декілька символів, то для розділення мусить бути знайдена вся послідовність separator
. Якщо separator
зустрічається на початку (або кінці) рядка, розділення все одно спрацьовує, внаслідок чого на початку (або в кінці) поверненого масиву з'являється порожній (тобто нульової довжини) рядок. Якщо separator
не зустрічається в str
, то повернений масив містить єдиний елемент, котрий містить ввесь рядок.
Якщо separator
– порожній рядок (""
), то str
перетворюється на масив своїх "символів" UTF-16, котрий не містить порожніх рядків на жодному зі своїх кінців.
[!NOTE] Таким чином, при передачі рядка як
separator
іlimit
зі значенням 0 –"".split("")
є єдиним способом отримати порожній масив.
[!WARNING] Коли як розділювач використовується порожній рядок (
""
), то рядок не ділиться на видимі символи (графемні кластери) чи символи Unicode (кодові точки), натомість – на кодові одиниці UTF-16. Отже – руйнуються сурогатні пари. Дивіться "Як на JavaScript отримати з рядка масив символів?" на Stack Overflow.
Якщо separator
є регулярним виразом, що дає збіг з порожніми рядками, то те, чи розбивається збіг на кодові одиниці UTF-16, чи на кодові точки Unicode, залежить від того, чи враховує регулярний вираз Unicode.
"😄😄".split(/(?:)/); // [ "\ud83d", "\ude04", "\ud83d", "\ude04" ]
"😄😄".split(/(?:)/u); // [ "😄", "😄" ]
Якщо separator
є регулярним виразом із групами захоплення, то при кожному збігу separator
отримані групи захоплення (включно з усіма результатами undefined
) додаються до результівного масиву. Така поведінка задана методом регулярного виразу Symbol.split
Якщо separator
є об'єктом з методом Symbol.split
, то цей метод викликається із передачею йому цільового рядка та limit
, а значенням this
є цей об'єкт. Результат виклику методу стає поверненим значенням split
.
Будь-яке інше значення перед використанням як роздільник буде приведено до рядка.
Приклади
Застосування split()
Коли рядок порожній і заданий непорожній розділювач, split()
повертає [""]
. Якщо і рядок, і розділювач є порожніми рядками, то повертається порожній масив.
const emptyString = "";
// рядок – порожній, а розділювач – ні
console.log(emptyString.split("a"));
// [""]
// і рядок, і розділювач – порожні рядки
console.log(emptyString.split(emptyString));
// []
В наступному прикладі оголошується функція, яка розділяє початковий рядок на масив рядків, використовуючи розділювач separator
. Після розділення функція друкує повідомлення з початковим рядком (до розділення), використаний розділювач, кількість елементів у масиві-результаті, а також самі окремі елементи цього масиву.
function splitString(stringToSplit, separator) {
const arrayOfStrings = stringToSplit.split(separator);
console.log("Початковий рядок —", stringToSplit);
console.log("Розділювач —", separator);
console.log(
"Масив містить",
arrayOfStrings.length,
"елементів:",
arrayOfStrings.join(" / "),
);
}
const tempestString = "Який чудесний світ новий оцей, де отакі є люди!";
const monthString = "Січ,Лют,Бер,Кві,Тра,Чер,Лип,Сер,Вер,Жов,Лис,Гру";
const space = " ";
const comma = ",";
splitString(tempestString, space);
splitString(tempestString);
splitString(monthString, comma);
Цей приклад видає наступний вивід:
Початковий рядок — "Який чудесний світ новий оцей, де отакі є люди!"
Розділювач — " "
Масив містить 9 елементів: Який / чудесний / світ / новий / оцей, / де / отакі / є / люди!.
Початковий рядок — "Який чудесний світ новий оцей, де отакі є люди!"
Розділювач — "undefined"
Масив містить 1 елемент: Який чудесний світ новий оцей, де отакі є люди!
Початковий рядок — "Січ,Лют,Бер,Кві,Тра,Чер,Лип,Сер,Вер,Жов,Лис,Гру"
Розділювач — ","
Масив містить 12 елементів: Січ / Лют / Бер / Кві / Тра / Чер / Лип / Сер / Вер / Жов / Лис / Гру
Видалення пробілів з рядка
В наступному прикладі split()
шукає нуль чи більше пробілів, за якими йде крапка з комою, далі – знову нуль чи більше пробілів, і, коли знаходить, видаляє їх з рядка. Масив nameList
містить результат, повернений з split()
.
const names =
"Сергій Мельник ;Антон Коваленко; Олена Шевченко ; Михайло Бондаренко ;Євген Бойко ";
console.log(names);
const re = /\s*(?:;|$)\s*/;
const nameList = names.split(re);
console.log(nameList);
Цей код записує два рядки: перший містить початкову стрічку тексту, а другий — масив із результатами.
Сергій Мельник ;Антон Коваленко; Олена Шевченко ; Михайло Бондаренко ;Євген Бойко
[ "Сергій Мельник", "Антон Коваленко", "Олена Шевченко", "Михайло Бондаренко", "Євген Бойко", "" ]
Повернення обмеженої кількості розділених значень
В наступному прикладі split()
шукає пробіли в рядку, і повертає перші три відділених значення з-поміж тих, які знаходить.
const myString = "Здрастуй, світе. Як ся маєш?";
const splits = myString.split(" ", 3);
console.log(splits);
Цей скрипт виводить наступне:
["Здрастуй,", "світе.", "Як"];
Розділення рядка за регулярним виразом RegExp
для включення частин розділювача в результат
Якщо separator
є регулярним виразом, що містить дужки для захоплення ( )
, знайдені збіги будуть також включені до масиву.
const myString = "Здрастуй 1 слово. Речення номер 2.";
const splits = myString.split(/(\d)/);
console.log(splits);
Цей скрипт виводить наступне:
["Здрастуй ", "1", " слово. Речення номер ", "2", "."];
[!NOTE]
\d
шукає збіги з класом символів, що відповідає цифрам від 0 до 9.
Використання власного розщеплювача
Об'єкт із методом Symbol.split
може використовуватися як розщеплювач з особливою логікою.
Наступний приклад розщеплює рядок, використовуючи внутрішній стан, що складається з числа, котре щоразу збільшується на одиницю:
const splitByNumber = {
[Symbol.split](str) {
let num = 1;
let pos = 0;
const result = [];
while (pos < str.length) {
const matchPos = str.indexOf(num, pos);
if (matchPos === -1) {
result.push(str.substring(pos));
break;
}
result.push(str.substring(pos, matchPos));
pos = matchPos + String(num).length;
num++;
}
return result;
},
};
const myString = "a1bc2c5d3e4f";
console.log(myString.split(splitByNumber)); // [ "a", "bc", "c5d", "e", "f" ]
Наступний приклад використовує внутрішній стан, щоб застосувати певну поведінку та пересвідчитися, що виробляється "дійсний" результат.
const DELIMITER = ";";
// Розщепити команди, але усунути будь-які недійсні чи непотрібні значення.
const splitCommands = {
[Symbol.split](str, lim) {
const results = [];
const state = {
on: false,
brightness: {
current: 2,
min: 1,
max: 3,
},
};
let pos = 0;
let matchPos = str.indexOf(DELIMITER, pos);
while (matchPos !== -1) {
const subString = str.slice(pos, matchPos).trim();
switch (subString) {
case "світло увімкнути":
// Якщо стан `on` вже `true` – нічого не робити.
if (!state.on) {
state.on = true;
results.push(subString);
}
break;
case "світло вимкнути":
// Якщо стан `on` вже `false` – нічого не робити.
if (state.on) {
state.on = false;
results.push(subString);
}
break;
case "яскравість збільшити":
// Накласти верхню межу яскравості.
if (state.brightness.current < state.brightness.max) {
state.brightness.current += 1;
results.push(subString);
}
break;
case "яскравість зменшити":
// Накласти нижню межу яскравості.
if (state.brightness.current > state.brightness.min) {
state.brightness.current -= 1;
results.push(subString);
}
break;
}
if (results.length === lim) {
break;
}
pos = matchPos + DELIMITER.length;
matchPos = str.indexOf(DELIMITER, pos);
}
// Якщо відбувся ранній вихід у зв'язку з досягненням межі кількості команд `lim` – решту команд не додавати.
if (results.length < lim) {
results.push(str.slice(pos).trim());
}
return results;
},
};
const commands =
"світло увімкнути; яскравість збільшити; яскравість збільшити; яскравість збільшити; світло увімкнути; яскравість зменшити; яскравість зменшити; світло вимкнути";
console.log(commands.split(splitCommands, 3)); // ["світло увімкнути", "яскравість збільшити", "яскравість зменшити"]
Специфікації
Сумісність із браузерами
desktop | mobile | server | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
split
|
Chrome Full support 1 | Edge Full support 12 | Firefox Full support 1 | Internet Explorer Full support 4 | Opera Full support 3 | Safari Full support 1 | WebView Android Full support 1 | Chrome Android Full support 18 | Firefox for Android Full support 4 | Opera Android Full support 10.1 | Safari on iOS Full support 1 | Samsung Internet Full support 1.0 | Deno Full support 1.0 | Node.js Full support 0.10.0 |