jQuery - Comment obtenir tous les styles / css (définis dans le document interne / externe) avec HTML d'un élément

Je sais que $("#divId").html() va me donner innerHtml. J'ai aussi besoin de son style (ce qui pourrait être défini par le biais de classes), soit en ligne style attribut ou tous les styles/classes au sein d'un distinct <style> tag.

Est-il possible?

Mise à JOUR

Que faire si le html est comme <div id="testDiv">cfwcvb</div> et une classe css pour #testDiv est défini dans la feuille de style externe?

Mise à JOUR 2

Désolé de ne pas clarifier cette plus tôt

Si c'est mon code HTML

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

Et les styles sont définis dans la feuille de style séparée ou dans la tête les styles.

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

Puis, quand j'essaie d'obtenir intérieure html de $("#divId").html() ou appeler une autre fonction personnalisée, j'ai besoin de quelque chose comme ci-dessous

<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>

Mise à JOUR 3 pour Répondre par kirilloid

J'ai couru code ci-dessous dans la Fenêtre de Commande de Chrome Débogueur outils pour cette page elle-même et c'est ce que je vois TypeError: Cannot read property 'rules' of undefined

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");

source d'informationauteur IsmailS