javascript 获取元素样式必杀技_Javascript教程-查字典教程网
javascript 获取元素样式必杀技
javascript 获取元素样式必杀技
发布时间:2016-12-30 来源:查字典编辑
摘要:Javascript获取CSS属性值方法:getComputedStyle和currentStyle1.对于元素的内联CSS样式(hello...

Javascript获取CSS属性值方法:getComputedStyle和currentStyle

1 .对于元素的内联CSS样式(<div>hello</div>),可以直接使用element.style.color来直接获取css属性的值;

2. 但是对于外部定义的css样式使用这种方式就无法获取了,而且IE浏览器和其他标准浏览器(Firefox,Chrome,Opera,Safari)使用的方法不一样,IE浏览器使用element.currentStyle,W3C标准浏览器使用getComputedStyle来获取。

1. IE获取元素外部定义的CSS属性值: element.currentStyle

currentStyle对象返回了元素上的样式表,但是style对象只返回通过style标签属性应用到元素的内嵌样式。

因此,通过currentStyle对象获取的样式值可能与通过style对象获取的样式值不同。

例如,如果段落的color属性值通过链接或嵌入样式表设置为红色( red ),而不是内嵌的话,对象.currentStyle.color 将返回正确的颜色,而对象style.color不能返回值。但是,如果用户指定了 <Pred'">,currentStyle和STYLE对象都将返回值 red。

currentStyle对象反映了样式表中的样式优先顺序。在 HTML 中此顺序为:

1) 内嵌样式

2) 样式表规则

3) HTML 标签属性

4) HTML 标签的内部定义

2. W3C获取元素外部定义的CSS属性值: window.getComputedStyle(element, pseudoElt)

element必选,HTML元素

pseudoElt必选,获取该元素的伪类样式

复制代码 代码如下:

function getStyle(node, property){

if (node.style[property]) {

return node.style[property];

}

else if (node.currentStyle) {

return node.currentStyle[property];

}

else if (document.defaultView && document.defaultView.getComputedStyle) {

var style = document.defaultView.getComputedStyle(node, null);

return style.getPropertyValue(property);

}

return null;

}

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新Javascript教程学习
    热门Javascript教程学习
    编程开发子分类