我想知道,当DOM中没有元素使用CSS值时,是否有一种方法可以从样式表文件中获取CSS值?我使用jQuery并使用选择器$(".classname").css()来获取值。但是在"classname“不在任何元素中的情况下,如何获取值”谢谢
发布于 2009-10-17 17:02:13
只需使用该类名创建一个元素并检查它。您甚至不需要将其附加到DOM:
var $el = $('<div class="classname"></div>');
var opacity = $el.css('opacity') // or whatever
即使$el
实际上并不存在于DOM中,您仍然可以访问它的所有样式属性。
编辑:正如评论中提到的,这种方法并不总是像预期的那样工作(例如,inherited css values没有明确定义在.classname上,selector specificity在.classname上定义,等等)。
例如,以下代码由于#foo
将选择器的专用性提高到独立.bar
之外而失败
css:
#foo .bar { color: red; }
js:
var $el = $('<div class="bar"></div>');
$el.css('color'); // Expected: "red", Actual: ""
发布于 2009-10-17 16:13:16
参见http://www.hunlock.com/blogs/Totally_Pwn_CSS_with_Javascript,它提供了一种跨浏览器的方法来动态获取和添加css。
它适用于document.styleSheets
和IE的.rules
以及其他所有人的.cssRules
它还有一个优点,那就是有点抽象,所以你不需要担心细节。
上面的链接不再起作用。以下是这篇博客文章的截图,由互联网档案馆wayback在2008年捕获。
该函数基本上遍历所有样式表的所有样式,并提供修改/删除它们的能力。
请注意,不推荐这样做,因为大多数现代样式表太大了,无法使其成为有效的操作。
发布于 2018-10-09 18:30:38
你可以去(这也适用于chrome):
var $elem = $('<div id="foo"></div>').appendTo('body'),
value = $elem.css('margin-top');
$('#foo').remove();
https://stackoverflow.com/questions/1582528
复制相似问题