首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >jQuery -如何获得元素的所有样式/css(在内部/外部文档中定义)

jQuery -如何获得元素的所有样式/css(在内部/外部文档中定义)
EN

Stack Overflow用户
提问于 2011-01-24 19:26:59
回答 9查看 41.7K关注 0票数 19

我知道$("#divId").html()会给我innerHtml的。我还需要它的样式(可能是通过类的方式定义的),要么是内嵌的style属性,要么是一个单独的<style>标记中的所有样式/类。

有可能吗?

更新

如果html类似于<div id="testDiv">cfwcvb</div>,并且在外部样式表中定义了用于#testDiv的css类,该怎么办?

更新2

很抱歉没有早点澄清这件事

如果这是我的HTML

代码语言:javascript
复制
<div id="divId">
    <span class="someClass">Some innerText</span>
</div>

并且样式在单独的样式表或头部样式中定义。

代码语言:javascript
复制
#divId {
    clear: both;
    padding: 3px;
    border: 2px dotted #CCC;
    font-size: 107%;
    line-height: 130%;
    width: 660px;
}
.someClass {
    color: blue;
}

然后,当我尝试获取$("#divId").html()的内部html或调用任何其他自定义函数时,我需要如下内容

代码语言:javascript
复制
<style>
#divId {
    clear: both;
    padding: 3px;
    border: 2px dotted #CCC;
    font-size: 107%;
    line-height: 130%;
    width: 660px;
}
.someClass {
    color: blue;
}
</style>

<div id="divId">
    <span class="someClass">Some innerText</span>
</div>

回答的更新3

我在this页面的Chrome调试器工具的命令窗口中运行了下面的代码,这就是我看到的TypeError: Cannot read property 'rules' of undefined

代码语言:javascript
复制
function getElementChildrenAndStyles(selector) {
  var html = $(selector).get(0).outerHTML;

  selector = selector.split(",").map(function(subselector){
    return subselector + "," + subselector + " *";
  }).join(",");
  elts = $(selector);

  var rulesUsed = [];
  // main part: walking through all declared style rules
  // and checking, whether it is applied to some element
  sheets = document.styleSheets;
  for(var c = 0; c < sheets.length; c++) {
    var rules = sheets[i].rules || sheets[i].cssRules;
    for(var r = 0; r < rules.length; r++) {
      var selectorText = rules[r].selectorText;
      var matchedElts = $(selectorText);
      for (var i = 0; i < elts.length; i++) {
        if (matchedElts.index(elts[i]) != -1) {
          rulesUsed.push(CSSrule); break;
        }
      }
    }
  }
  var style = rulesUsed.map(function(cssRule){
    if ($.browser.msie) {
      var cssText = cssRule.style.cssText.toLowerCase();
    } else {
      var cssText = cssRule.cssText;
    }
    // some beautifying of css
    return cssText.replace(/(\{|;)\s+/g, "\$1\n  ").replace(/\A\s+}/, "}");
    //                 set indent for css here ^ 
  }).join("\n");
  return "<style>\n" + style + "\n</style>\n\n" + html;
};
getElementChildrenAndStyles(".post-text:first");
EN

回答 9

Stack Overflow用户

回答已采纳

发布于 2011-02-08 05:13:29

outerHTML (不确定,您需要它-以防万一)

限制:使用CSSOM,并且样式表应该来自同一来源。

代码语言:javascript
复制
function getElementChildrenAndStyles(selector) {
  var html = $(selector).outerHTML();

  selector = selector.split(",").map(function(subselector){
    return subselector + "," + subselector + " *";
  }).join(",");
  elts = $(selector);

  var rulesUsed = [];
  // main part: walking through all declared style rules
  // and checking, whether it is applied to some element
  sheets = document.styleSheets;
  for(var c = 0; c < sheets.length; c++) {
    var rules = sheets[c].rules || sheets[c].cssRules;
    for(var r = 0; r < rules.length; r++) {
      var selectorText = rules[r].selectorText;
      var matchedElts = $(selectorText);
      for (var i = 0; i < elts.length; i++) {
        if (matchedElts.index(elts[i]) != -1) {
          rulesUsed.push(rules[r]); break;
        }
      }
    }
  }
  var style = rulesUsed.map(function(cssRule){
    if (cssRule.style) {
      var cssText = cssRule.style.cssText.toLowerCase();
    } else {
      var cssText = cssRule.cssText;
    }
    // some beautifying of css
    return cssText.replace(/(\{|;)\s+/g, "\$1\n  ").replace(/\A\s+}/, "}");
    //                 set indent for css here ^ 
  }).join("\n");
  return "<style>\n" + style + "\n</style>\n\n" + html;
}

用法:

代码语言:javascript
复制
getElementChildrenAndStyles("#divId");
票数 13
EN

Stack Overflow用户

发布于 2011-02-07 21:43:25

没有jQuery和IE支持,这就是我能做的:

代码语言:javascript
复制
<!doctype html>

<html>
    <head>
        <meta charset = "utf-8">

        <script type = "text/javascript">
            Element.prototype.getStyles = function () {
                var array = {};
                var styles = window.getComputedStyle (this, null);

                for (var i = 0; i < styles.length; i ++) {
                    var style = styles[i];

                    array[style] = styles[style];
                }

                return array; // return new Array (array, this.innerHTML); You can also return the HTMl content. I don't think its necessary
            }

            window.addEventListener ("load", function () {
                var divId = document.getElementById ("divId");
                var someClass = document.getElementsByClassName ("someClass");

                var string = "";
                var styles = divId.getStyles ();

                for (var i in styles) {
                    string += i + ": " + styles[i] + "\n";
                }

                alert (string);
                alert ("In-line style: Height ->" + styles["height"] + "\n" + "Out-line style: Width ->" + styles["width"])
                alert ("HTML: " + divId.innerHTML);

                // Same thing with the span element
            }, false);
        </script>

        <style>
            #divId {
                clear: both;
                padding: 3px;
                border: 2px dotted #CCC;
                font-size: 107%;
                line-height: 130%;
                width: 660px;
            }
            .someClass {
                color: blue;
            }
        </style>

        <title>Test</title>
    </head>

    <body>
        <div id = "divId" style = "height: 100px">
            <span class = "someClass">Some innerText</span>
        </div>
    </body>
</html>
票数 8
EN

Stack Overflow用户

发布于 2011-02-02 21:03:35

您可以使用大多数浏览器中的window.getComputedStyle()和IE中元素的currentStyle属性来获取代表元素计算样式的style对象。但是,在返回快捷方式属性(如background)、颜色RGB值、长度甚至font-weight (请参见this useful test page)的值方面,浏览器有几个不同之处。仔细测试。

代码语言:javascript
复制
function computedStyle(el) {
    return el.currentStyle || window.getComputedStyle(el, null);
}

alert(computedStyle(document.body).color);
票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4781410

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档