javascript 获取元素样式必杀技
2014-05-04 00:00
821 查看
Javascript获取CSS属性值方法:getComputedStyle和currentStyle
1 .对于元素的内联CSS样式(<div style="color:#369">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不能返回值。但是,如果用户指定了 <P STYLE="color:'red'">,currentStyle和STYLE对象都将返回值 red。
currentStyle对象反映了样式表中的样式优先顺序。在 HTML 中此顺序为:
1) 内嵌样式
2) 样式表规则
3) HTML 标签属性
4) HTML 标签的内部定义
2. W3C获取元素外部定义的CSS属性值: window.getComputedStyle(element, pseudoElt)
element必选,HTML元素
pseudoElt必选,获取该元素的伪类样式
1 .对于元素的内联CSS样式(<div style="color:#369">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不能返回值。但是,如果用户指定了 <P STYLE="color:'red'">,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; }
相关文章推荐
- 新手上路,JSP乱码问题(笔记)
- JSF2.0实战 - 6、TextBox
- javascript中的构造函数
- Javascript 对象方式实现命名参数调用(下):自动包装偏函数
- 常用js函数整理
- 【Javascript】OOP ‘终端' demo
- urllib2、re、json的综合使用
- 使用JavaScript获取电池状态的方法
- JavaScript source map 的意义
- js:对象的创建(基于组合和动态原型)
- 利用JSP交互式打印表格
- HTML5 Canvas+JS控制电脑或手机上的摄像头实例
- 深入理解JavaScript中的prototype和call()的作用
- 【BZOJ】【P1013】【JSOI2008】【球形空间产生器sphere】【题解】【高斯消元】
- Javascript 对象方式实现命名参数调用(上):原理和手动实现
- JavaScript判断图片是否加载完成的三种方式
- 俄罗斯方块_javascript
- JS 删除字符串最后一个字符的几种方法
- JavaScript中函数声明优先于变量声明
- JavaScript判断图片是否加载完成的三种方式