首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在没有DOM元素的情况下获取css值

在没有DOM元素的情况下获取css值
EN

Stack Overflow用户
提问于 2009-10-17 16:07:06
回答 5查看 6K关注 0票数 12

我想知道,当DOM中没有元素使用CSS值时,是否有一种方法可以从样式表文件中获取CSS值?我使用jQuery并使用选择器$(".classname").css()来获取值。但是在"classname“不在任何元素中的情况下,如何获取值”谢谢

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2009-10-17 17:02:13

只需使用该类名创建一个元素并检查它。您甚至不需要将其附加到DOM:

代码语言:javascript
运行
复制
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:

代码语言:javascript
运行
复制
#foo .bar { color: red; }

js:

代码语言:javascript
运行
复制
var $el = $('<div class="bar"></div>');
$el.css('color'); // Expected: "red", Actual: ""
票数 13
EN

Stack Overflow用户

发布于 2009-10-17 16:13:16

参见http://www.hunlock.com/blogs/Totally_Pwn_CSS_with_Javascript,它提供了一种跨浏览器的方法来动态获取和添加css。

它适用于document.styleSheets和IE的.rules以及其他所有人的.cssRules

它还有一个优点,那就是有点抽象,所以你不需要担心细节。

上面的链接不再起作用。以下是这篇博客文章的截图,由互联网档案馆wayback在2008年捕获。

该函数基本上遍历所有样式表的所有样式,并提供修改/删除它们的能力。

请注意,不推荐这样做,因为大多数现代样式表太大了,无法使其成为有效的操作。

票数 4
EN

Stack Overflow用户

发布于 2018-10-09 18:30:38

你可以去(这也适用于chrome):

代码语言:javascript
运行
复制
var $elem = $('<div id="foo"></div>').appendTo('body'),
    value = $elem.css('margin-top');

$('#foo').remove();
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1582528

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档