• 技术文章 >web前端 >js教程

    JavaScript中如何替换字符串?3种方法介绍

    青灯夜游青灯夜游2020-11-02 17:49:06转载2659

    替换字符串中的文本是 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

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

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

    相关免费学习推荐:js视频教程

    更多编程相关知识,请访问:编程入门!!

    以上就是JavaScript中如何替换字符串?3种方法介绍的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:segmentfault,如有侵犯,请联系admin@php.cn删除
    专题推荐:javascript 字符串
    上一篇:在Node.js中如何使用EventEmitter处理事件? 下一篇:js的原型和原型链是什么
    线上培训班

    相关文章推荐

    • 详解JavaScript中的作用域和作用域链• 网页显示javascript是什么原因• 10 个有用的javascript Math对象方法(推荐)• JavaScript中判断变量是否为数字的3种方法(附代码)• 28 个提升JavaScript开发效率的 VSCode 插件

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网