当前位置: 首页 > 面试题库 >

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

戚同
2023-03-14
问题内容

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

td { padding: 0.2em 1.2em }

td { padding: 0.32em 2em }

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

可以更改样式定义吗?


问题答案:

可以通过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本身并没有为您提供任何特殊的工具来访问样式表,但是有可能存在一些插件。



 类似资料:
  • 问题内容: 我正在建立一个多语言站点,所有者正在帮助我进行一些翻译。一些显示的短语需要换行以保持网站的风格。 不幸的是,所有者不是计算机专家,所以如果他看到他有机会在翻译时以某种方式修改数据。 是否有CSS解决方案(除了更改宽度)适用于在每个单词之后都会中断的元素? (我知道我可以用PHP做到这一点,但我想知道是否有一个我不知道的CSS技巧可以完成同一件事,也许是在CJK功能中。) 编辑 我将尝试

  • 问题内容: 是否可以通过JavaScript更改CSS伪元素样式? 例如,我想像这样动态设置滚动条的颜色: 而且我还希望能够告诉滚动条这样隐藏: 但是,这两个脚本都返回: 未捕获的TypeError:无法读取null的属性“样式” 还有其他解决方法吗?跨浏览器的互操作性并不重要,我只需要它在Webkit浏览器中即可工作。 问题答案: 编辑 : 从技术上讲,有一种通过JavaScript直接更改CS

  • 本文向大家介绍JQuery操作元素的css样式,包括了JQuery操作元素的css样式的使用技巧和注意事项,需要的朋友参考一下 我们常常要使用Javascript来改变页面元素的样式。其中一种办法是改变页面元 素的CSS类(Class),这在传统的Javascript里,我们通常是通过处理HTML Dom的classname特性来实现的;而jQuery里提供三种方法来实现这个功能, 虽然它们和传统

  • 问题内容: jQuery中是否有一种方法可以从现有元素中获取所有CSS并将其应用于另一个元素而无需列出所有元素? 我知道如果它们是带有的样式属性都可以,但是我所有的样式都在外部样式表中。 问题答案: 迟了几年,但是这里有一个可以同时检索内联样式和外部样式的解决方案: 将jQuery对象传递给,它将返回一个对象,然后您可以将其插回jQuery的,例如: :)

  • 问题内容: 当我将鼠标悬停在ID为“ a”的div或类上时,是否可以更改ID为“ b”的div或类的背景色? 问题答案: 是的,您可以执行此操作,但前提是在HTML之后。 如果紧随其后: 这是使用相邻的同级组合器()。 如果和之间还有其他元素,则可以使用以下元素: 这是使用通用的同级组合器()。 双方并在所有现代浏览器和IE7 +工作 如果是的后代,则可以简单地使用。 替代方案:您可以使用纯CSS