原生javascript获取元素样式


Posted in Javascript onDecember 31, 2014

摘要:
    我们在开发过程中经常会遇到通过js获取或者改变DOM元素的样式,方法有很多,比如:通过更改DOM元素的class。现在我们讨论原生js来获取DOM元素的CSS样式,注意是获取不是设置

    在开始之前先说下获取最终应用在元素上的所有CSS属性对象的意思是,如果没有给元素设置任何样式,也会把浏览器默认的样式返回来。

1、ele.style
    在学习DOM的时候就看到通过ele.style来获取元素样式值,但是有时候获取的并非是节点的样式值,而是空值。这是因为ele.style只能获取写在元素标签中的style属性里的样式值,无法获取到定义在<style></style>和通过<link href="css.css">加载进来的样式属性

    例子:

        var test = document.getElementById("test");

        //获取节点的color

        test.style.color;

2、getComputedStyle()
    getComputedStyle是一个可以获取当前元素所有最终使用的CSS属性值。

    语法如下:

        window.getComputedStyle("元素", "伪类");

    这个方法接受两个参数:要取得计算样式的元素和一个伪元素字符串(例如“:before”) 。如果不需要伪元素信息,第二个参数可以是null。也可以通过document.defaultView.getComputedStyle("元素", "伪类");来使用

    例子:

        var test = document.getElementById("test"),

        demo = window.getComputedStyle(test, null); 

        //获取节点的color

         demo.color 

    注意:Firefox和Safari会将颜色转换成rgb格式,如果test节点上没有任何样式,通过style.length来查看浏览器默认样式的个数。IE6-8不支持该方法,需要使用下面的方法

3、ele.currentStyle
    currentStyle是IE浏览器自己的一个属性,其语法与ele.style类似,差别在于element.currentStyle返回的是元素当前应用的最终CSS属性值(包括外链CSS文件,页面中嵌入的<style>属性等)。

    语法:

        var style = dom.currentStyle;

    例子:

        var test = document.getElementById("test"),

        demo = test.currentStyle; 

        //获取节点的color

        demo.color;

     注意:对于综合属性border等,ie返回undefined,其他浏览器有的返回值,有的不返回,但是borderLeftWidth这样的属性是返回值的

4、getPropertyValue()
    getPropertyValue获取CSS样式的直接属性名称

    语法如下:

        window.getComputedStyle(element, null).getPropertyValue(属性)

    例子:

      var test = document.getElementById('test');

      window.getComputedStyle(test, null).getPropertyValue("background-color");

     注意:属性名不支持驼峰格式,IE6-8不支持该方法,需要使用下面的方法

5、getAttribute
    getAttribute与getPropertyValue类似,有一点的差异是属性名驼峰格式

    例子:

        var test = document.getElementById('test');

        window.getComputedStyle(test, null).getPropertyValue("backgroundColor");

    注意:该方法只支持IE6-8

小结:
    jQuery的CSS()方法,其底层运作就应用了getComputedStyle以及getPropertyValue方法,当我们使用原生的js开发时就可以通过以上方法获取元素的值。

下面是一个兼容ie,firefox,chrome等浏览器的获取元素样式的方法,可以应用到项目中

 function getStyle(ele) {

     var style = null;

     

     if(window.getComputedStyle) {

         style = window.getComputedStyle(ele, null);

     }else{

         style = ele.currentStyle;

     }

     

     return style;

 }
Javascript 相关文章推荐
使用JavaScript switch case 另类写法
Mar 14 Javascript
如何解决Jquery库及其他库之间的$命名冲突
Sep 15 Javascript
js实现幻灯片播放图片示例代码
Nov 07 Javascript
jquery实现翻动fadeIn显示的方法
Mar 05 Javascript
JavaScript简单获取页面图片原始尺寸的方法
Jun 21 Javascript
AngularJS 面试题集锦
Sep 06 Javascript
js实现前端分页页码管理
Jan 06 Javascript
详解在vue-cli中引用jQuery、bootstrap以及使用sass、less编写css
Nov 08 jQuery
Vue 实现手动刷新组件的方法
Feb 19 Javascript
vue实现axios图片上传功能
Aug 20 Javascript
webpack HappyPack实战详解
Oct 08 Javascript
Weex开发之地图篇的具体使用
Oct 16 Javascript
JavaScript分析、压缩工具JavaScript Analyser
Dec 31 #Javascript
jQuery中:last-child选择器用法实例
Dec 31 #Javascript
jQuery中:nth-child选择器用法实例
Dec 31 #Javascript
jQuery中:first-child选择器用法实例
Dec 31 #Javascript
jQuery中复合属性选择器用法实例
Dec 31 #Javascript
javascript实现左右控制无缝滚动
Dec 31 #Javascript
javascript比较两个日期的先后示例代码
Dec 31 #Javascript
You might like
?繁体转换的class
2006/10/09 PHP
PHP判断文件是否存在、是否可读、目录是否存在的代码
2012/10/03 PHP
PHP页面转UTF-8中文编码乱码的解决办法
2015/10/20 PHP
PHP微信开发用Cache 解决数据缓存
2016/07/11 PHP
PHP面向对象程序设计组合模式与装饰模式详解
2016/12/02 PHP
PHP简单实现记录网站访问量功能示例
2018/06/06 PHP
微信公众号之主动给用户发送消息功能
2019/06/22 PHP
PHP+redis实现微博的拉模型案例详解
2019/07/10 PHP
Javascript实例教程(19) 使用HoTMetal(3)
2006/12/23 Javascript
用tip解决Ext列宽度不够的问题
2008/12/13 Javascript
jquery的$getjson调用并获取远程的JSON字符串问题
2012/12/10 Javascript
基于jquery插件实现常见的幻灯片效果
2013/11/01 Javascript
JavaScript中对循环语句的优化技巧深入探讨
2014/06/06 Javascript
jquery控制页面部分刷新的方法
2015/06/24 Javascript
Vue.js实战之组件之间的数据传递
2017/04/01 Javascript
如何使用JS在HTML中自定义字符串格式化
2017/07/20 Javascript
jQuery实现点击自身以外区域关闭弹出层功能完整示例【改进版】
2018/07/31 jQuery
详解Vue CLI3配置解析之css.extract
2018/09/14 Javascript
Element Input组件分析小结
2018/10/11 Javascript
vue项目启动出现cannot GET /服务错误的解决方法
2020/04/26 Javascript
javascript实现移动端触屏拖拽功能
2020/07/29 Javascript
[02:35]DOTA2英雄基础教程 狙击手
2014/01/14 DOTA
Python2.6版本中实现字典推导 PEP 274(Dict Comprehensions)
2015/04/28 Python
CentOS安装pillow报错的解决方法
2016/01/27 Python
Python MySQLdb 使用utf-8 编码插入中文数据问题
2018/03/13 Python
Python读写及备份oracle数据库操作示例
2018/05/17 Python
python3实现表白神器
2019/04/09 Python
Python+pyftpdlib实现局域网文件互传
2020/08/24 Python
pycharm配置QtDesigner的超详细方法
2021/01/25 Python
Python基于argparse与ConfigParser库进行入参解析与ini parser
2021/02/02 Python
HTML5 微格式和相关的属性名称
2010/02/10 HTML / CSS
什么是Web Service?
2012/07/25 面试题
幼儿园教师节活动方案
2014/02/02 职场文书
农村门前三包责任书
2014/07/25 职场文书
办公室个人总结
2015/02/28 职场文书
某学校的2019年度工作报告范本
2019/10/11 职场文书