[转]currentStyle和getComputedStyle的兼容写法
2015-08-31 10:06
363 查看
currentStyle:获取计算后的样式,也叫当前样式、最终样式。
优点:可以获取元素的最终样式,包括浏览器的默认值,而不像style只能获取行间样式,所以更常用到。
注意:不能获取复合样式如background属性值,只能获取单一样式如background-color等。
非常遗憾的是,这个好使的东西也不能被各大浏览器完美地支持。准确地说,在我测试的浏览器中,IE8和Opera 11弹出了“object CSSStyleDeclaration”;FF 12、chrome 14、safari 5则弹出“undefined”。
虽然currentStyle无法适用于所有浏览器,但是可以根据以上测试的结果来区分开支持、不支持的浏览器,然后再找到兼容的写法。
其实在FF浏览器中我们可以使用getComputedStyle(obj,false)来达到与IE下currentStyle相同的效果。
getComputedStyle(obj,false):在FF新版本中只需要第一个参数,即操作对象,第二个参数写“false”也是大家通用的写法,目的是为了兼容老版本的火狐浏览器。
兼容写法:
一个空白页面中body的id=”abc”,测试以上代码,IE和Opera弹出“auto”,其它三款浏览器则弹出“***px”。虽然结果不同,但是可以发现chrome和safari也都和火狐一样,顺利地读取到了属性值。不支持currentStyle的三款浏览器(FF、chrome、safari),都是支持getComputedStyle的。
结果表明:对浏览器是否支持currentStyle的判断 + getComputedStyle,就可以做到兼容各主流浏览器的效果。而且兼容写法并不复杂,你掌握了吗?^_^
支持currentStyle:IE、Opera
支持getComputedStyle:FireFox、Chrome、Safari
注意最后的弹出内容,currentStyle返回浏览器的默认值”auto”,而getComputedStyle则返回具体的值”**px”。这应该是两者的一个小差异,有兴趣的童鞋可以一起交流研究下。
更多相关:
更多javascript入门知识:javascript笔记。
54173BLOG原创,转载请保留链接: http://www.mming.cc/blog/?p=549。
优点:可以获取元素的最终样式,包括浏览器的默认值,而不像style只能获取行间样式,所以更常用到。
注意:不能获取复合样式如background属性值,只能获取单一样式如background-color等。
alert (oAbc.currentStyle);
非常遗憾的是,这个好使的东西也不能被各大浏览器完美地支持。准确地说,在我测试的浏览器中,IE8和Opera 11弹出了“object CSSStyleDeclaration”;FF 12、chrome 14、safari 5则弹出“undefined”。
虽然currentStyle无法适用于所有浏览器,但是可以根据以上测试的结果来区分开支持、不支持的浏览器,然后再找到兼容的写法。
var oAbc = document.getElementById("abc"); if(oAbc.currentStyle) { //IE、Opera alert("我支持currentStyle"); } else { //FF、chrome、safari alert("我不支持currentStyle"); }
其实在FF浏览器中我们可以使用getComputedStyle(obj,false)来达到与IE下currentStyle相同的效果。
getComputedStyle(obj,false):在FF新版本中只需要第一个参数,即操作对象,第二个参数写“false”也是大家通用的写法,目的是为了兼容老版本的火狐浏览器。
兼容写法:
var oAbc = document.getElementById("abc"); if(oAbc.currentStyle) { //IE、Opera //alert("我支持currentStyle"); alert(oAbc.currentStyle.width); } else { //FF、chrome、safari //alert("我不支持currentStyle"); alert(getComputedStyle(oAbc,false).width); }
一个空白页面中body的id=”abc”,测试以上代码,IE和Opera弹出“auto”,其它三款浏览器则弹出“***px”。虽然结果不同,但是可以发现chrome和safari也都和火狐一样,顺利地读取到了属性值。不支持currentStyle的三款浏览器(FF、chrome、safari),都是支持getComputedStyle的。
结果表明:对浏览器是否支持currentStyle的判断 + getComputedStyle,就可以做到兼容各主流浏览器的效果。而且兼容写法并不复杂,你掌握了吗?^_^
支持currentStyle:IE、Opera
支持getComputedStyle:FireFox、Chrome、Safari
注意最后的弹出内容,currentStyle返回浏览器的默认值”auto”,而getComputedStyle则返回具体的值”**px”。这应该是两者的一个小差异,有兴趣的童鞋可以一起交流研究下。
更多相关:
更多javascript入门知识:javascript笔记。
54173BLOG原创,转载请保留链接: http://www.mming.cc/blog/?p=549。
相关文章推荐
- 解决The Apache Axis2 Web service runtime in Tomcat v7.0 Server does not support the service project 问
- kvm(十)虚拟机存储池
- 大学入試改革―本当に実現できるのか
- TCP字节流和UDP数据报区别
- 通过fetchXml 实现分页查询
- 数据验证插件的使用validator.js
- Mysql 常用引擎的特点及选择使用策略
- android 的四种枚举Context.MODE_PRIVATE
- N!中末尾0的个数
- 函数 描述 PHP
- Mybatis使用及原理解析
- 大数加减法
- 未能加载文件或程序集“XXX”或它的某一个依赖项。磁盘空间不足---解决方案
- [软件工程]提前完成任务的风险如何定义
- 页面 Backspace 功能禁锢
- 未能加载文件或程序集“XXX”或它的某一个依赖项。磁盘空间不足---解决方案
- 问题:C#时间差;结果:C# 使用TimeSpan计算两个时间差
- 【LeetCode】70. Climbing Stairs
- 创建Windows服务(Windows Services)N种方式总结
- 压缩、打包和解压缩