原生JS中如何获取CSS属性中的值

html-css05

原生JS中如何获取CSS属性中的值,第1张

您好,使用原生js获取

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

返回的是一个CSS样式声明对象 , 只读, 此方法支持Firefox浏览器

语法:var style=window.getComputedStyle(“元素”,“伪类”)第一个参数是必须的,第二个为可选的。

二、currentStyle 是一款可以兼容IE浏览器的属性返回的是当前所有最终使用的CSS属性值,

利用element.CurrentStyle.attribute可获取

其与getComputedStyle区别:1、 currentStyle不支持伪类样式获取;

2、currentStyle不支持现代浏览器,支持IE

原生JS中如何获取CSS属性中的值

obj.style方法,这个方法只能JS只能获取写在html标签中的写在style属性中的值(style=”…”),看下面代码

XML/HTML代码

<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd“>

<html xmlns=”http://www.w3.org/1999/xhtml“>

<head>

<meta http-equiv=”Content-Type” content=”text/htmlcharset=utf-8″ />

<title>JS获取CSS属性值</title>

<style type=”text/css”>

<!–

.ss{color:#cdcdcd}

–>

</style>

</head>

<body>

<div id=”css88″ class=”ss” style=”width:200pxheight:200pxbackground:#333333″>JS获取CSS属性值</div>

<script type=”text/javascript”>

alert(document.getElementById(“css88”).style.width)//200px

alert(document.getElementById(“css88”).style.color)//空白

</script>

</body>

</html>

上面这个例子对id为”css88″的div设置了2种烦事的样式,包括style和外部样式class。

从alert出来的信息可以看到,document.getElementById(“css88”).style方法获取不到class为ss的属性和值。

IE中使用的是obj.currentStyle方法,而FF是用的是getComputedStyle 方法。

另外一个方法是:

XML/HTML代码

<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd“>

<html xmlns=”http://www.w3.org/1999/xhtml“>

<head>

<meta http-equiv=”Content-Type” content=”text/htmlcharset=utf-8″ />

<title>S获取CSS属性值</title>

<style type=”text/css”>

<!–

.ss{background:bluecolor:#cdcdcdwidth:200px}

–>

</style>

</head>

<body>

<p id=”qq” class=”ss” >sdf</p>

<script type=”text/javascript”>

function GetCurrentStyle (obj, prop) {

if (obj.currentStyle) {

return obj.currentStyle[prop]

}

else if (window.getComputedStyle) {

propprop = prop.replace (/([A-Z])/g, “-$1”)

propprop = prop.toLowerCase ()

return document.defaultView.getComputedStyle (obj,null)[prop]

}

return null

}

var dd=document.getElementById(“qq”)

alert(GetCurrentStyle(dd,”width”))

</script>

</body>

</html>

当然,如果您是引用外部的css文件同样适用。

另:可以将上面的方法简化为

JavaScript代码

function getDefaultStyle(obj,attribute){ // 返回最终样式函数,兼容IE和DOM,设置参数:元素对象、样式特性

return obj.currentStyle?obj.currentStyle[attribute]:document.defaultView.getComputedStyle(obj,false)[attribute]

}