利用JavaScript获取浏览器计算后的样式

HTML5学堂:JavaScript可以用style对象给标签设置样式、获取样式,但是利用style对象获取的样式只能是标签内联的样式,今天要给大家讲解的是利用currentStyle对象与getComputedStyle方法来获取浏览器计算后的样式。

哪些样式是属于浏览器计算后的样式

要检测标签的样式有包含在头部书写样式、标签内联样式和外部的样式,即浏览器计算后的样式。

getComputedStyle(element[, pseudoElt])方法

element用于计算样式的标签;pseudoElt可选指定一个伪元素进行匹配。对于常规的元素来说可省略。

window.getComputedStyle(element[, pseudoElt])方法获取标签在浏览器里计算的样式。

实例

<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>HTML5Course - 梦幻雪冰</title>
<link rel="stylesheet" href="reset.css">
<script type="text/javascript" src="jquery-1.8.3.min.js"></script>
<style>
    .btn {
        width: 100px;
    }
    .btn:after {
        display: block;
        width: 20px;
        height: 20px;
        background-color: red;
        content: ".";
    }
</style>
</head>
<body>
<div class="btn" id="con">HTML5学堂:刘国利、陈能堡</div>
<script>
    var box = document.getElementById("con");
    box.style.height = "1000px";


    // 获取标签浏览器计算后的样式
    console.log(window.getComputedStyle(box, null).getPropertyValue("height"));
    console.log(window.getComputedStyle(box, null).getPropertyValue("width"));
    // 获取伪元素浏览器计算后的样式
    console.log(window.getComputedStyle(box, "after")["content"]);
    console.log(window.getComputedStyle(box, "after")["background-color"]);
    // 注意:getComputedStyle(box, null).getPropertyValue("height")等价于getComputedStyle(box, null)["height"]
</script>
</body>
</html>

关于defaultView

在许多JavaScript框架, getComputedStyle是通过 document.defaultView 对象来调用的。 大部分情况下,这是不需要的,因为可以直接通过window对象调用。但有一种情况,你必需要使用 defaultView, 那是在火狐3.6上访问子框架内的样式 (iframe)——资料来源mozilla

jQuery部分源代码

实例

<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>HTML5Course - 梦幻雪冰</title>
<link rel="stylesheet" href="reset.css">
<script type="text/javascript" src="jquery-1.8.3.min.js"></script>
<style>
    .btn {
        width: 100px;
    }
    .btn:after {
        display: block;
        width: 20px;
        height: 20px;
        background-color: red;
        content: ".";
    }
</style>
</head>
<body>
<div class="btn" id="con">HTML5学堂:刘国利、陈能堡</div>
<script>
    var box = document.getElementById("con");
    box.style.height = "1000px";


    // 获取标签浏览器计算后的样式
    console.log(document.defaultView.getComputedStyle(box, null).getPropertyValue("height"));
    console.log(document.defaultView.getComputedStyle(box, null).getPropertyValue("width"));
    // 获取伪元素浏览器计算后的样式
    console.log(document.defaultView.getComputedStyle(box, "after")["content"]);
    console.log(document.defaultView.getComputedStyle(box, "after")["background-color"]);
</script>
</body>
</html>

浏览器支持程度

currentStyle对象是IE浏览器专有

从上面可以看出IE6~8不支持getComputedStyle该方法,利用currentStyle对象处理兼容咯~

实例

<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>HTML5Course - 梦幻雪冰</title>
<link rel="stylesheet" href="reset.css">
<script type="text/javascript" src="jquery-1.8.3.min.js"></script>
<style>
    .btn {
        width: 100px;
    }
    .btn:after {
        display: block;
        width: 20px;
        height: 20px;
        background-color: red;
        content: ".";
    }
</style>
</head>
<body>
<div class="btn" id="con">HTML5学堂:刘国利、陈能堡</div>
<script>
    var box = document.getElementById("con");
    box.style.height = "1000px";


    // 获取标签浏览器计算后的样式
    console.log(box.currentStyle["width"]);
    console.log(box.currentStyle["height"]);


    // 注意:获取伪元素浏览器计算后的样式——该对象不支持
</script>
</body>
</html>

获取标签浏览器计算后的样式兼容处理

/*
* 功能:获取渲染后标签的样式,element是标签的对象,property是标签样式属性值
* 参数:element是元素对象,property是样式属性
* demo:getStyle(move, "marginLeft");
* author:HTML5学堂
*/
function getStyle(element, property){
var proValue = null;
if (!document.defaultView) {
    proValue = element.currentStyle[property];
} else {
    proValue = document.defaultView.getComputedStyle(element)[property];
}
return proValue;
}

原文发布于微信公众号 - HTML5学堂(h5course-com)

原文发表时间:2015-11-16

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏静默虚空的博客

jQuery DOM操作

对节点的操作 查找节点 查找节点可以直接利用jQuery选择器来完成,非常便利。 插入节点 jQuery提供了8种插入节点的方法。 序号 方法 ...

2216
来自专栏进击的君君的前端之路

CSS选择器知识点整理

1635
来自专栏HTML5学堂

CSS 1.0~3.0选择器(中)

HTML5学堂:上一篇 讲到CSS1.0~CSS3.0选择器的兼容问题等,CSS选择器的使用是特别广泛的,大家也会经常用到,而用到的选择器有哪些?接下来本文会介...

2863
来自专栏从零开始学 Web 前端

从零开始学 Web 之 jQuery(五)操作元素其他属性,为元素绑定事件

如果我们在设置为原来宽高2倍的时候,就要先把获取的宽高转换成数字类型,再乘以2,这样操作比较麻烦,有没有简单的方法呢?

1274
来自专栏闻道于事

JavaWeb(八)JQuery

jQuery 市场用得比较多两个框架: jQuery 比较适合做一些互联网 的应用(12306.com,蘑菇街,美丽说,聚美) extjs 比较适合做后台管理系...

2774
来自专栏zaking's

CSS(CSS3)选择器(1)

这篇文章主要用于存储CSS以及CSS3的选择器部分知识,以便日后查阅及记忆. 该内容分为两部分,第一部分为css选择器的一些基本知识。第二部分为CSS3新增...

28710
来自专栏JetpropelledSnake

Web前端学习笔记之jQuery选择器

经过一晚上的查找整理,终于整理出一套应该算最全面的JQuery选择过滤器的方法了。所有代码均经过测试。 首先HTML代码

791
来自专栏web

设置第一个字母字体变大并且所有字母大小写 及下划线

1395
来自专栏向治洪

android之View绘制

Android系统的视图结构的设计也采用了组合模式,即View作为所有图形的基类,Viewgroup对View继承扩展为视图容器类,由此就得到了视图部分的基本...

1569
来自专栏天天

DOM

1103

扫码关注云+社区