javascript获取元素CSS值window.getComputedStyle

获取元素div的height

源代码:

<div id="box"></div>
<style>
*{ padding:0; margin:0px;}
ul,li{ list-style:none;}
#box{ width:100px; height:100px; padding:50px; border:25px solid #0F3; margin:25px; opacity:0.5; filter:alpha(opacity=50); }
</style>

var box = document.getElementById("box");
方法:

1、box.style.height可以获取到height的值,但是只能获取到内嵌样式中(即style属性中)的css样式

2、window.getComputedStyle(“元素”,“伪类”)方法会在一个元素应用完有效样式且计算完所有属性的基本值之后给出所有 CSS 属性的值。

输出window.getComputedStyle(box,null),返回的是一个 CSSStyleDeclaration 对象,当元素的样式更改时,它会自动更新本身。但其不兼容IE6-8。

3、IE中使用box.currentStyle

综合:
function getStyle(element,attr){
	var val;
	if("getComputedStyle" in window){
		val = window.getComputedStyle(element,null)[attr];	
	}else{
		val = element.currentStyle[attr];	
	}
	return val;
}
但是由于不同浏览器返回的属性名不同,例如:
float:火狐,谷歌;
cssFloat:IE9-11;
styleFloat:IE6-8;
getStyle(box,"float");//IE9-11为undefined
getStyle(box,"styleFloat");//IE9-11、火狐、谷歌为undefined
getStyle(box,"cssFloat");//IE6-8为undefined

所以使用getPropertyValue来获取某一属性的值,但是不兼容IE6-8,但是IE本身有一个方法getAttribute。
getStyle优化为:
function win(element,attr){
	var val;
	if("getComputedStyle" in window){
		val = window.getComputedStyle(element,null).getPropertyValue(attr);	
	}else{
		val = element.currentStyle.getAttribute(attr);	
	}
	return val;
}
完美解决属性名不同的所造成的部分浏览器返回值为undefined。
但是其中height的值单位为em,返回值IE6-8的值单位是em,标准浏览器的值单位是px。
里面还有属性名或返回属性值不一致的问题,欢迎补充。



评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值