微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

jQuery从ALL元素中删除样式属性

我知道如何从一个元素中删除属性,已经有一些帖子:
$("div.preview").removeAttr("style");

这是HTML代码

<div class="preview" style="background-color:white">
   <p>Some text<span style="font-size:15px;">some text</span></p>
   some more code
</div>

问题是这将从预览div中删除样式属性.我想从该div中的所有元素中删除.这只是一个例子,在实际情况下会有更广泛的html.

有没有办法做到这一点?

更新:
太好了,我现在知道怎么做但是如果html被发送到函数作为字符串存储在变量中.所以代替

$("div.preview")

我有

var string = '<div class="preview"><p style='font-size:15px;'>....</p><div>'

有什么办法可以说下面这样的东西吗?

$(string).find(*).removeAttr("style");

解决方法

您可以使用通配符选择器*来选择div.preview下的所有内容.

jsFiddle

$('div.preview *').removeAttr('style');

更新

RE:你的相关问题,如果我们有一个字符串而不是DOM元素.我们可以将它们转换为jQuery对象,删除上述属性,然后将其转换(如果需要).

jsFiddle

// jQuery extension to get an element's outer HTML
// https://stackoverflow.com/a/2419877/1156119
jQuery.fn.outerHTML = function(s) {
    return s
        ? this.before(s).remove()
        : jQuery("<p>").append(this.eq(0).clone()).html();
};

var string = '<div class="preview"><p style="font-size:15px;">....</p><div>'
var elements = $(string);
elements.find('*').removeAttr('style');

var withoutStyles = elements.outerHTML();
alert(withoutStyles);

原文地址:https://www.jb51.cc/jquery/176062.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐