我有下面的HTML字符串。JavaScript中删除字符串前导和尾随空白的示例代码是什么?

<p>&nbsp;&nbsp;</p>
<div>&nbsp;</div>
Trimming using JavaScript<br />
<br />
<br />
<br />
all leading and trailing white spaces
<p>&nbsp;&nbsp;</p>
<div>&nbsp;</div>

当前回答

string.replace(/^\s+|\s+$/g, "");

其他回答

我知道这是一个非常古老的问题,但它仍然没有一个公认的答案。我看到你想要删除以下内容:html标签是“空的”和基于html字符串的空白。

我已经提出了一个解决方案,根据你的评论,你正在寻找的输出:

Trimming using JavaScript<br /><br /><br /><br />all leading and trailing white spaces 

var str = "<p>&nbsp;&nbsp;</p><div>&nbsp;</div>使用JavaScript修剪<br /><br /><br /><br />所有前导和尾空格<p>&nbsp;&nbsp;</p><div>&nbsp;</div>"; console.log (str.trim () .replace (/, / g,”)。取代 (/<[^\/>][^>]*><\/[^>]+>/ g, " "));

.trim()删除前导和尾随空格

.replace(/&nbsp;/g, ")删除&nbsp;

.replace (/<[^\/>][^>]*><\/[^>]+>/ g, " "));删除空标签

var str = "  my awesome string   "
str.trim();    

对于旧的浏览器,使用regex

str = str.replace(/^[ ]+|[ ]+$/g,'')
//str = "my awesome string" 

如果你正在处理一个多行字符串,比如一个代码文件:

<html>
    <title>test</title>
    <body>
        <h1>test</h1>
    </body>
</html>

并替换所有前导行,得到这样的结果:

<html>
<title>test</title>
<body>
<h1>test</h1>
</body>
</html>

你必须添加多行标记到你的正则表达式,^和$逐行匹配:

string.replace(/^\s+|\s+$/gm, '');

相关文档引用:

“m”标志表示多行输入字符串应被视为多行。例如,如果使用"m", "^"和"$"将从仅匹配整个字符串的开头或结尾改为匹配字符串中任何一行的开头或结尾。

var trim = your_string.replace(/^\s+|\s+$/g, '');
string.replace(/^\s+|\s+$/g, "");