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

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

创新互联主要从事成都网站设计、做网站、网页设计、企业做网站、公司建网站等业务。立足成都服务永登,10年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:13518219792

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

 
 
 
  1. const myMessage = 'this is the sentence to end all sentences'; 
  2. const newMessage = myMessage.replace('sentence', 'message'); 
  3. console.log(newMessage); // this is the message to end all sentences 

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

替换多个子串

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

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

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

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

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

替换特殊字符

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

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

可以用 replace() 做到:

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

或者用new Regexp():

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

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

分享名称:JavaScript中替换字符串的几种方法
转载来源:http://www.shufengxianlan.com/qtweb/news31/50881.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联