AI智能
改变未来

JavaScript 中替换字符串的几种方法


JavaScript 中替换字符串的几种方法

前端小混混 前端先锋

// 每日前端夜话 第418篇
// 正文共:700 字
// 预计阅读时间:5 分钟

替换字符串中的文本是 JavaScript 开发中的常见任务。本文研究几种用 replace 和正则表达式替换文本的方法。

替换单个字串

通常 JavaScript 的 String replace() 函数只会替换它在字符串中找到的第一个匹配的子符:

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

在这个例子中,仅替换了第一个 sentence 字串。

替换多个子串

如果希望 JavaScript 能够替换所有子串,必须通过 /g 运算符使用正则表达式:

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

这一次次两个子串都会被替换。

除了使用内联 /g 之外,还可以使用 RegExp 对象的构造函数:

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```

替换特殊字符

要替换特殊字符,例如 -/\\^$*+?.()|[]{}),需要使用反斜杠对其转义。

如果给定字符串 this-is-my-url,要求把所有转义的减号( -)替换为未转义的减号(-)。

可以用 replace() 做到:

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

或者用new Regexp():

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

在第二个例子中不必用反斜杠来转义反斜杠。

你还知道哪些方法,请留言告诉大家。

赞(0) 打赏
未经允许不得转载:爱站程序员基地 » JavaScript 中替换字符串的几种方法