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

IT技术 javascript jquery css stylesheet
2021-03-09 07:20:01

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

td { padding: 0.2em 1.2em }

td { padding: 0.32em 2em }

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

是否可以更改样式定义?

5个回答

可以通过 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问题的规则是第一个样式表中的第一条规则。如果没有,您可能需要通过迭代规则来寻找正确的 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 本身并没有为您提供任何特殊的工具来访问样式表,但可能有插件可以。

@Tomalak:是的 - 事实上,规范中没有要求selectorText包含与原始选择器完全相同的字符串。它与innerHTML- 解析器将源转换为一堆对象,然后读取属性导致序列化结果,该序列化是反映浏览器正在使用的信息的文本表示,但不能以任何方式保证序列化与来源相同。因此,精确搜索selectorText本质上是不可靠的。
2021-04-18 07:20:01
值得注意的是,IE(包括 IE10)不保留原始selectorText. .foo.bar在 CSS 样式表中编写的内容可能最终会.bar.foo在 DOM 规则对象中出现。这使得“寻找正确的选择器文本”变得异常脆弱。
2021-05-08 07:20:01
这个答案最好的部分是:“更好的方法......祖先的阶级变化”
2021-05-09 07:20:01
$('head').append('<style id="customCSS">td { padding: 0.32em 2em }</style>');

我添加了一个 id 属性,这样当您不再希望应用该更改时,您可以定位并删除它。

$('#customCSS').remove();
这会添加和删除,但不会改变
2021-05-16 07:20:01

我遇到了一个问题,在加载并执行此操作之前,我不知道我想要一个类的宽度。

<script>
$(function() {
    calcWidth = CalculateWidth();

    $('body').prepend('<style> .dynamicWidth { width: ' + calcWidth + 'px } </style>');
}
</script>

注意:根据您希望规则“级联”的方式,放置脚本的位置(前置、附加)可能很重要。

不,它只是不能这样工作......不确定有什么比这更好的解释方式:)

jQuery 旨在处理元素......如果你这样做是为了测试,Chrome 控制台的 Firebug 是选项。

可以做的事情是拥有一个服务器端生成的样式表,例如ThemeRoller如何做到这一点,并且 jQuery(或 vanilla JS)将其动态添加<link>到您的标题中,例如:

<link rel="stylesheet" href="myCSS.php?tdPad=.32|2" type="text/css" /> 

如果它是最后一个链接,它会覆盖之前定义的样式……事实上,这正是ThemeRoller 的工作方式。

现在这可以通过使用CSS 变量来实现

CSS:

:root{
--my-padding: 0.2em 1.2em;
}

td{
padding:var(--my-padding)
}

jQuery:

let paddingX = 0.32
let paddingY = 2
$(':root').css('--my-padding',`${paddingX }em ${paddingY }em`)