String.prototype.replaceAll()
Метод replaceAll()
(замінити все) значень String
повертає новий рядок, в якому всі збіги з патерном pattern
замінені переданим значенням replacement
. Значенням pattern
може бути як рядок, так і RegExp
, а replacement
може бути рядком або функцією, яка буде викликана для кожного знайденого збігу.Початковий рядок залишається незмінним.
Спробуйте його в дії
Синтаксис
replaceAll(pattern, replacement)
Параметри
pattern
(патерн)може бути рядком чи об'єктом з методом
Symbol.replace
– типовим зразком чого є регулярні вирази. Будь-яке значення, котре не має методаSymbol.replace
, буде зведено до рядка.Якщо
pattern
є регулярним виразом, то він мусить мати позначку глобальності (g
), інакше – буде викинутоTypeError
.replacement
(заміна)Може бути рядком чи функцією. Заміна має таку само семантику, як для
String.prototype.replace()
.
Повернене значення
Новий рядок, в якому всі збіги з патерном замінені вказаним значенням.
Винятки
TypeError
Викидається, якщо
pattern
є регулярним виразом, котрий не має позначки глобальності (g
), тобто його властивістьflags
не містить"g"
.
Опис
Цей метод не видозмінює рядкове значення, на котрому його викликали. Він повертає новий рядок.
На відміну від replace()
, цей метод замінює всі входження рядка, а не тільки перше. Попри те, що також можливо застосувати replace()
з динамічно сконструйованим за допомогою RegExp()
глобальним регулярним виразом, аби замінити всі входження рядка, це може мати небажані наслідки, якщо цей рядок вміщає спеціальні символи, що мають значення в регулярних виразах (а це може статися, якщо рядок заміни надходить від користувача). Попри те, що цьому можна запобігти, застосувавши RegExp.escape()
, перетворивши регулярний вираз на літеральний патерн, краще просто застосувати replaceAll()
та передати рядок, не перетворюючи його на регулярний вираз.
function unsafeRedactName(text, name) {
return text.replace(new RegExp(name, "g"), "[ВИДАЛЕНО]");
}
function safeRedactName(text, name) {
return text.replaceAll(name, "[ВИДАЛЕНО]");
}
const report =
"Хакер на ім'я ха.*ер використав спеціальні символи в своєму імені для зламу сервера.";
console.log(unsafeRedactName(report, "ха.*ер")); // "Хакер на ім'я [ВИДАЛЕНО]а."
console.log(safeRedactName(report, "ха.*ер")); // "Хакер на ім'я [ВИДАЛЕНО] використав спеціальні символи в своєму імені для зламу сервера."
Якщо pattern
є об'єктом з методом Symbol.replace
(в т.ч. об'єктом RegExp
), то такий метод викликається з цільовим рядком та replacement
як аргументами. Повернене значення стає поверненим значенням replaceAll()
. У такому випадку логіка replaceAll()
повністю закодована у методі [Symbol.replace]()
, а отже – матиме такий само результат, як replace()
(окрім додаткової валідації введення – перевірки того, що регулярний вираз є глобальним).
Якщо pattern
є порожнім рядком, то заміна буде вставлена між кожними двома кодовими одиницями UTF-16, подібно до поведінки split()
.
"xxx".replaceAll("", "_"); // "_x_x_x_"
Для отримання подробиць про те, як властивості регулярних виразів (особливо позначку липкості) взаємодіють із replaceAll()
– дивіться RegExp.prototype[Symbol.replace]()
.
Приклади
Застосування методу replaceAll()
"aabbcc".replaceAll("b", ".");
// 'aa..cc'
Регулярний вираз без глобального пошуку викидає виняток
Якщо шукане значення вказано як регулярний вираз, то такий вираз повинен бути глобальним. Наступний підхід не спрацює:
"aabbcc".replaceAll(/b/, ".");
// TypeError: replaceAll must be called with a global RegExp
Проте такий варіант працюватиме:
'aabbcc'.replaceAll(/b/g, '.');
"aa..cc"
Специфікації
Сумісність з браузерами
desktop | mobile | server | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
replaceAll
|
Chrome Full support 85 | Edge Full support 85 | Firefox Full support 77 | Internet Explorer No support Ні | Opera Full support 71 | Safari Full support 13.1 | WebView Android Full support 85 | Chrome Android Full support 85 | Firefox for Android Full support 79 | Opera Android Full support 60 | Safari on iOS Full support 13.4 | Samsung Internet Full support 14.0 | Deno Full support 1.2 | Node.js Full support 15.0.0 |
Дивіться також
- Поліфіл методу
String.prototype.replaceAll
доступний уcore-js
String.prototype.replace()
String.prototype.match()
RegExp.prototype.exec()
RegExp.prototype.test()