我还没有看到任何文档说 jQuery 可以更改任何 CSS 定义,例如更改
td { padding: 0.2em 1.2em }
to
td { padding: 0.32em 2em }
但要么必须更改整个样式表,要么更改每个元素的类,要么更改每个元素的 css。
可以更改样式定义吗?
可以通过 DOM 访问样式表,但这是我们倾向于避免的事情之一,因为 IE 需要大量的兼容性问题。
更好的方法通常是在祖先上使用简单的类更改来间接触发更改:
td { padding: 0.2em 1.2em }
body.changed td { padding: 0.32em 2em }
现在只是$('body').addClass('changed')
和所有的td
更新。
如果你真的必须放弃样式表:
var sheet= document.styleSheets[0];
var rules= 'cssRules' in sheet? sheet.cssRules : sheet.rules; // IE compatibility
rules[0].style.padding= '0.32em 2em';
这假设td
所讨论的规则是第一个样式表中的第一条规则。如果没有,您可能必须通过迭代规则来寻找正确的选择器文本。或者只是在末尾添加一条新规则,覆盖旧规则:
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 本身并没有为您提供任何特殊的工具来访问样式表,但可能有插件可以提供。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)