Maison  >  Article  >  interface Web  >  Comment remplacer toutes les occurrences d’une chaîne en JavaScript ?

Comment remplacer toutes les occurrences d’une chaîne en JavaScript ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-10-25 08:13:03819parcourir

How to Replace All Occurrences of a String in JavaScript?

Remplacer toutes les instances d'une chaîne en JavaScript

Étant donné une chaîne du type "Test abc test test abc test test test abc test test abc", en remplaçant la première occurrence de "abc" utilisant string.replace('abc', '') est insuffisant. Cette question explique comment remplacer toutes occurrences d'une chaîne en JavaScript.

Solution moderne (ECMAScript 2021 et versions ultérieures) :

Pour les navigateurs modernes qui prennent en charge la spécification ECMAScript 2021, vous pouvez utiliser la méthode String.replaceAll() :

<code class="javascript">str = str.replaceAll('abc', '');</code>

Solution de navigateur héritée :

Pour les navigateurs plus anciens ou hérités qui manquent String.replaceAll(), la fonction personnalisée suivante peut être utilisée :

<code class="javascript">function replaceAll(str, find, replace) {
  return str.replace(new RegExp(escapeRegExp(find), 'g'), replace);
}

function escapeRegExp(str) {
  return str.replace(/[.*+?^${}()|[\]\]/g, '\$&'); // $& means the whole matched string
}</code>

Ce modèle a été affiné plusieurs fois, aboutissant finalement à la fonction replaceAll() ci-dessus, qui prend en charge les arguments de chaîne dans le paramètre find par pré-production. -les traiter pour échapper aux caractères spéciaux.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn