JavaScript 中替換字符串的幾種方法

替換字符串中的文本是 JavaScript 開發中的常見任務。本文研究幾種用 replace 和正則表達式替換文本的方法。

替換單個字串

通常 JavaScript 的 String replace() 函數只會替換它在字符串中找到的第一個匹配的子符:

<code>const myMessage = 'this is the sentence to end all sentences';
const newMessage = myMessage.replace('sentence', 'message');
console.log(newMessage); // this is the message to end all sentences
/<code>

在這個例子中,僅替換了第一個 sentence 字串。

替換多個子串

如果希望 JavaScript 能夠替換所有子串,必須通過 /g 運算符使用正則表達式:

<code>const myMessage = 'this is the sentence to end all sentences';
const newMessage = myMessage.replace(/sentence/g, 'message');
console.log(newMessage); // this is the message to end all messages
/<code>

這一次次兩個子串都會被替換。

除了使用內聯 /g 之外,還可以使用 RegExp 對象的構造函數:

<code>const myMessage = 'this is the sentence to end all sentences';
const newMessage = myMessage.replace(new RegExp('sentence', 'g'), 'message');
console.log(newMessage); // this is the message to end all messages```
/<code>

替換特殊字符

要替換特殊字符,例如 -/\^$*+?.()|[]{}),需要使用反斜槓對其轉義。

如果給定字符串 this\-is\-my\-url,要求把所有轉義的減號(\-)替換為未轉義的減號(-)。

可以用 replace() 做到:

<code>const myUrl = 'this\-is\-my\-url';
const newUrl = myMessage.replace(/\\-/g, '-');
console.log(newUrl); // this-is-my-url
/<code>

或者用new Regexp():

<code>const myUrl = 'this\-is\-my\-url';
const newUrl = myUrl.replace(new RegExp('\-', 'g'), '-');
console.log(newUrl); // this-is-my-url
/<code>
<code>const myUrl = 'this\-is\-my\-url';
const newUrl = myUrl.replace(new RegExp('\-', 'g'), '-');
console.log(newUrl); // this-is-my-url
/<code>
JavaScript 中替換字符串的幾種方法

<code>const myUrl = 'this\-is\-my\-url';
const newUrl = myUrl.replace(new RegExp('\-', 'g'), '-');
console.log(newUrl); // this-is-my-url
/<code>

在第二個例子中不必用反斜槓來轉義反斜槓。


分享到:


相關文章: