类 CSS 属性返回
如何返回一个类计算的 CSS 属性/属性数组?
例如,如果我在 CSS 中定义了一个类:
.global {
background-color: red;
color: white;
text-shadow: 0px 1px 1px black;
}
它会通过 javascript 随时应用于 element
。现在我想将此 elements
childrens' color
更改为 parents' (.global
) 元素背景颜色
。
有没有办法从 style
标签中先前定义的类或外部包含的 *.css
读取 CSS 属性?
类似于 getCSSData([span|.global|div > h1]);
(其中传递的变量是 CSS 选择器,它获取完全匹配元素的数据),它将返回一个对象,其中每个它自己的可访问变量中的属性?
类似于:
cssdata = {
selector : '.global',
properties : {
backgroundColor : 'red',
color : 'white',
textShadow : '0px 1px 1px black'
// plus inherited, default ones (the ones specified by W3..)
}
}
我之前解释的示例的用法是:
// just an example to include both, jQuery usage and/or native javascript
var elements = $('.global').children() || document.getElementsByClassName('.global')[0].children;
var data = $('.global').getCSSData() || document.getCSSData('.global');
return elements.css('color', data.properties.backgroundColor) || elements.style.backgroundColor = data.properties.backgroundColor;
javascript
/jquery
中是否已经内置了一个函数,而我忽略了它?
如果没有,我应该寻找什么来制作一个?
PS 也可以是 DOM Level 3..(HTML5'ish..)
How would one return a class computed CSS property/property array?
Like, if I have a class defined in CSS:
.global {
background-color: red;
color: white;
text-shadow: 0px 1px 1px black;
}
It's applied on the go with javascript to an element
. Now I want to change this elements
childrens' color
to parents' (.global
) element background-color
.
And is there a way to read CSS properties from a previously defined class in a style
tag or externally included *.css
?
Something like, getCSSData([span|.global|div > h1]);
(where the passed variable is a CSS selector, that gets data for exactly matching element) that would return an object with each property in it's own accessible variable?
Something like:
cssdata = {
selector : '.global',
properties : {
backgroundColor : 'red',
color : 'white',
textShadow : '0px 1px 1px black'
// plus inherited, default ones (the ones specified by W3..)
}
}
And the usage for my previously explained example would be:
// just an example to include both, jQuery usage and/or native javascript
var elements = $('.global').children() || document.getElementsByClassName('.global')[0].children;
var data = $('.global').getCSSData() || document.getCSSData('.global');
return elements.css('color', data.properties.backgroundColor) || elements.style.backgroundColor = data.properties.backgroundColor;
Is there a function built in already in javascript
/jquery
and I've overlooked it?
If not, what should I look for to make one?
P.S. Can be DOM Level 3 too.. (HTML5'ish..)
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
如果您想获取父元素的背景颜色,然后将该颜色应用于所有子元素的字体,您可以使用以下代码。
这是 jsFiddle.net 上的示例
If you want to grab the background color of the parent element and then apply that color to the font of all of it's children you could use the following code.
Here's an example on jsFiddle.net
您可以访问包含所有继承样式值的元素的计算样式,下面是在控制台中输出 div 元素的计算样式的示例。
您可以在这里找到更多信息:http://help.dottoro.com/ljscsoax.php
You can access the computedStyle of an element which includes all inherited style values, here is a example that outputs the computed style of a div element in the console.
You can find more information here: http://help.dottoro.com/ljscsoax.php
如果我正确理解你的问题,你想找到一种修改类的通用方法;并使该修改影响该类的所有实例化。这是关于 SO 的另一个详细讨论的主题在这里。
事实证明,有一种非常有趣且有用的类处理方式,几乎可以在所有浏览器中使用,特别是 IE8 及更低版本除外。
If I understand your question correctly, you'd like to find a general approach to modifying a class; and to have that modifcation affect all of the instantiations of that class. This was the subject of another detailed discussion on SO over here.
There turned out to be an extremely interesting and useful treatment of classes that works in almost all browsers, notably excepting IE8 and below.