正则匹配标签内的空格问题

发布于 2022-09-12 13:19:53 字数 652 浏览 14 评论 0

image

我尝试用/(<.*?>)\s(.*?)(<\/.*?>)/g 匹配
// 正则表达式
let rex = `/(<.*?>)\s(.*?)(<\/.*?>)/g`;
// 原字符串
let str = `<p class="ss" ><br>         tab空格 </p> <p>  普通空格</p><p>没有空格</p>`;
// 匹配
let res = str.replace(rex,`$1&nbsp;$2$3`)
// 控制台打印
console.log(res)
// 得到的结果是 `<p class="ss" ><br>&nbsp;        tab空格 </p> <p>&nbsp; 普通空格</p><p>没有空格</p>`

得到的结果是只匹配标签内的一个空格, 请问怎么实现标签内的空格都替换成   呢?
在线匹配测试地址

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

梦境 2022-09-19 13:19:53
var result = '<p class="ss" ><br>         tab空格 </p> <p>  普通空格</p><p>没有空格</p>'
.replace(/(\s*<[^>]+>)([^<>]*)(<\/[^>]+>\s*)/g, function(str, $1, $2, $3) {
  return [$1.trim(), $2.trim(), $3.trim()].join('')
})

// "<p class="ss" ><br>tab空格</p><p>普通空格</p><p>没有空格</p>"
console.log(result)
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文