JavaScript で出現するすべての文字列を置換することは、テキスト データを扱うときによく必要になることがあります。ただし、 string.replace() メソッドを使用すると、最初に出現したものだけが置換される可能性があるため、困惑することになります。ここでは、ソリューションとその進化について包括的に説明します。
ECMAScript 2021 をサポートする最新のブラウザの場合、String.replaceAll() メソッドは洗練されたソリューションを提供します。 。出現するすべての文字列を新しい値に直接置き換えます。
str = str.replaceAll('abc', '');
古いブラウザまたはレガシー ブラウザの場合、カスタム関数を使用して、望ましい結果:
function replaceAll(str, find, replace) { return str.replace(new RegExp(escapeRegExp(find), 'g'), replace); }
ここで、escapeRegExp は検索内の特殊文字をエスケープするためのヘルパー関数です。 string:
function escapeRegExp(str) { return str.replace(/[.*+?^${}()|[\]\]/g, '\$&'); }
正規表現は、検索文字列内の特殊文字と競合する可能性があります。 escapeRegExp を使用して文字列を前処理すると、正確な一致と置換が保証されます。
var find = 'abc'; var re = new RegExp(escapeRegExp(find), 'g'); str = str.replace(re, '');
元のソリューションは、新しい RegExp 行を次のように置き換えることによって簡素化できます。
function replaceAll(str, find, replace) { return str.replace(new RegExp(find, 'g'), replace); }
フィルタリングせずに渡すときは、安全のためにescapeRegExpを忘れずに含めてください引数:
function replaceAll(str, find, replace) { return str.replace(new RegExp(escapeRegExp(find), 'g'), replace); }
これらの手順に従い、JavaScript での文字列操作の微妙な違いを理解することで、アプリケーション内で出現するすべての文字列を効果的に置換できるようになります。
以上がJavaScript で出現する文字列をすべて置換するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。