使用JS将字符串中的下划线替换为空格
要用字符串中的空格替换下划线,请调用 replaceAll()
方法,将下划线和空格作为参数传递给它,例如 str.replaceAll('_', ' ')
。replaceAll
方法将返回一个新字符串,其中每个下划线都被一个空格替换。
const str = 'apple_pear_melon';
// ✅ without regular expression
const result1 = str.replaceAll('_', ' ');
console.log(result1); // 👉️ "apple pear melon"
// ✅ with regular expression
const result2 = str.replace(/_+/g, ' ');
console.log(result2); // 👉️ "apple pear melon"
replaceAll
示例将每个下划线替换为一个空格,而 replace
方法将一个或多个相邻的下划线替换为一个空格。
我们将以下 2 个参数传递给 String.replaceAll
方法:
- 我们要在字符串中匹配的子字符串
- 每个匹配的替换
replaceAll
方法不会改变原始字符串,它会返回一个新字符串。 字符串在 JavaScript 中是不可变的。
另一种方法是使用 String.replace
方法。
使用 replace 将字符串中的下划线替换为空格
要用字符串中的空格替换下划线:
-
使用以下正则表达式调用
replace()
方法 -/_+/g
。 - 用包含空格的字符串替换每个匹配项。
-
replace()
方法将返回一个新字符串,其中所有下划线都替换为空格。
const str = 'apple_pear_melon';
const result2 = str.replace(/_+/g, ' ');
console.log(result2); // 👉️ "apple pear melon"
我们传递给 replace()
方法的第一个参数是正则表达式,第二个参数是正则表达式的每个匹配项的替换。
正斜杠 //
标记正则表达式的开始和结束。
正则表达式匹配下划线。
加号
+
与前面的项目(下划线)匹配一次或多次。 换句话说,我们认为多个下划线彼此相邻是一个匹配项,并将它们替换为一个空格。
我们使用了 g
(全局)标志,因为我们想要匹配字符串中出现的所有下划线,而不仅仅是第一次出现的。
如果只想用空格替换字符串中的第一个下划线,请删除 g
标志。
const str = 'apple_pear_melon';
const replaceFirst = str.replace(/_+/, ' ');
console.log(replaceFirst); // 👉️ "apple pear_melon"
如果在阅读正则表达式方面需要帮助,请查看我们的正则表达式教程 。
可能存在我们必须处理的极端情况 - 字符串可能以下划线开头或结尾,在这种情况下我们可能希望删除前导或尾随空格。
// 👇 ️starts and ends with underscore
const str = '_apple_pear_melon_';
const result3 = str.replaceAll('_', ' ').trim();
console.log(result3); // 👉️ "apple pear melon"
String.trim
方法从字符串中删除任何前导或尾随空格(空格、制表符、换行符)。
console.log(' apple '.trim()); // 👉️ "apple"
为了处理这种边缘情况,我们只需在用空格替换下划线后调用 trim()
方法。
另一种常用的替代方法是使用 String.split
和 Array.join
方法。
const str = '_apple_pear_melon_';
const result4 = str.split('_').join(' ').trim();
console.log(result4); // 👉️ "apple pear melon"
我们传递给 split()
方法的唯一参数是我们要拆分字符串的分隔符。
该方法返回一个子字符串数组。
// 👇️ ['one', 'two', 'three']
console.log('one_two_three'.split('_'));
然后我们在数组上调用 join()
方法并传递一个空格作为分隔符。
// 👇️ "one two three"
console.log('one_two_three'.split('_').join(' '));
选择哪种方法是个人喜好的问题。 我会选择
replaceAll
方法,因为我发现它最直接、可读性和直观性。
相关文章
将 HTML 转换为 JSON
发布时间:2023/05/05 浏览次数:135 分类:HTML
-
本篇文章介绍如何将 HTML 转换为 JSON。使用 JavaScript JSON.stringify() 方法将 HTML 转换为 JSON JSON 类似于 JavaScript 对象,不同的是 key 在 JSON 中被写成一个字符串。
Django 返回 JSON
发布时间:2023/05/04 浏览次数:106 分类:Python
-
在与我们的讨论中,我们简要介绍了 JSON 格式,并讨论了如何借助 Django 中的 JsonResponse 类将数据返回为 JSON 格式。
在 Go 中将 JSON 转换为 struct 结构体
发布时间:2023/04/27 浏览次数:65 分类:Go
-
本篇文章介绍如何将 JSON 转换为 GoLang 中的 struct。在 Go 中使用 Unmarshal 方法将 JSON 转换为 Struct
将 Python 类对象序列化为 JSON
发布时间:2023/04/25 浏览次数:154 分类:Python
-
本教程介绍序列化过程。 它还说明了我们如何使用 toJSON() 方法使 JSON 类可序列化,并包装 JSON 以转储到其类中。
Python 使用 JSON Diff 比较多级 JSON 对象
发布时间:2023/04/25 浏览次数:78 分类:Python
-
本文旨在介绍我们如何在Python中比较两个多级 JSON 对象并确定它们是否相同。
使用 Python 将数据附加到 JSON 文件
发布时间:2023/04/25 浏览次数:85 分类:Python
-
大多数 Web 应用程序和 Rest API 向用户提供 JSON 格式的数据,因为它在 Web 应用程序中被广泛使用且易于理解。 本教程介绍了使用 Python 将数据附加到 JSON 文件的可能方法。
如何在 Python 中将 JSON 转换为字典
发布时间:2023/04/22 浏览次数:186 分类:Python
-
在 Python 中,JSON(JavaScript Object Notation)是一种轻量级数据交换格式,常用于将数据从服务器发送到客户端。当我们需要将 JSON 数据解析为 Python 字典时,可以使用内置的 json 模块。本文
使用 NodeJS 检查 MongoDB 中是否存在集合
发布时间:2023/04/21 浏览次数:194 分类:MongoDB
-
在本文中,我们将检查 MongoDB 数据库中是否存在一个集合,并且我们还将查看与主题相关的示例,以使主题更容易理解。 为此,我们将使用 Node.js。