我有这个字符串:
var str = '<p>paragraph<a>link</a></p>
<div class="myclass">
<div>something</div>
<div style="mystyle">something</div>
<b><a href="#">link</a></b>
<b><a href="#" name="a name">link</a></b>
<b style="color:red">bold</b>
<img src="../path" alt="something" />
<img src="../path" alt="something" class="myclass" />
</div>';
我想删除除 href
之外的所有属性, src
, alt
。所以这是预期的结果:
/*
<p>paragraph<a>link</a></p>
<div>
<div>something</div>
<div>something</div>
<b><a href="#">link</a></b>
<b><a href="#">link</a></b>
<b>bold</b>
<img src="../path" alt="something">
<img src="../path" alt="something">
</div>
我怎样才能做到这一点?
<小时/>我可以只选择它们,但没有用:
最佳答案
var str = `<p>paragraph<a>link</a></p>
<div class="myclass">
<div>something</div>
<div style="mystyle">something</div>
<b><a href="#">link</a></b>
<b><a href="#" name="a name">link</a></b>
<b style="color:red">bold</b>
<img src="../path" alt="something" />
<img src="../path" alt="something" class="myclass" />
</div>`;
var div = document.createElement("div");
div.innerHTML=str;
div.querySelectorAll("*").forEach(function(el){
for (var i = 0, atts = el.attributes, n = atts.length; i < n; i++){
var att = atts[i].nodeName;
if (["src","alt","href"].indexOf(att) ==-1) el.removeAttribute(att);
}
});
// console.log(div); alert shows it more clearly
alert(div.innerHTML);
PS:请注意,您需要反引号来引用嵌入换行符的字符串
关于javascript - 如何删除除特定属性之外的所有标签属性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41923316/