小编典典

jQuery可以更改CSS样式定义吗?(不是每个元素的单个CSS)

css

我还没有看到任何文档说jQuery可以更改任何CSS定义,例如更改

td { padding: 0.2em 1.2em }

td { padding: 0.32em 2em }

但要么必须更改整个样式表,要么更改每个元素的类,或者更改每个元素的css。

可以更改样式定义吗?


阅读 291

收藏
2020-05-16

共1个答案

小编典典

可以通过DOM访问样式表,但这是我们倾向于避免的事情之一,因为IE需要大量的兼容性问题。

更好的方法通常是使用祖先的简单类更改来间接触发更改:

td { padding: 0.2em 1.2em }
body.changed td { padding: 0.32em 2em }

现在$('body').addClass('changed'),所有tds都会更新。

如果您确实必须修改样式表,请执行以下操作:

var sheet= document.styleSheets[0];
var rules= 'cssRules' in sheet? sheet.cssRules : sheet.rules; // IE compatibility
rules[0].style.padding= '0.32em 2em';

假定所讨论的td规则是第一个样式表中的第一个规则。如果不是,您可能必须通过迭代规则以寻找正确的selectorText来进行搜索。或者只是在末尾添加一个新规则,以覆盖旧规则:

if ('insertRule' in sheet)
    sheet.insertRule('td { padding: 0.32em 2em }', rules.length);
else // IE compatibility
    sheet.addRule('td', 'padding: 0.32em 2em', rules.length);

jQuery本身并没有为您提供任何特殊的工具来访问样式表,但是有可能存在一些插件。

2020-05-16