JS中如何获取CSS属性

在原来html页面中代码:<divclass="h-table">更<br/>新<br/>下<br/>载<br/></div>能将h-tab的属性显示出来。因为设计需要,... 在原来html页面中代码:
<div class="h-table">
更<br />新<br />
下<br />载<br />

</div>
能将h-tab的属性显示出来。
因为设计需要,将这段代码放入JS中,给DIV定义了一个新的ID为 cxdw_bq,
h-tab的背景等属性不再生效。
JS代码如下:
str = "<div id=\"gx_bq\" class=\"h-table\">更<br />新<br />";

document.getElementById('h-table').insertAdjacentHTML("beforeEnd",str);
谢谢回答!还请教个问题,如果用你这种方式,那后面那个属性该怎么写?document.getElementById('h-table').insertAdjacentHTML("beforeEnd",str);
这个意思将div id=\"gx_bq\" class=\"h-table\">更<br />新<br />"插入到h-table中
展开
 我来答
维湾教育培训
推荐于2016-04-07 · 知道合伙人软件行家
维湾教育培训
知道合伙人软件行家
采纳数:3549 获赞数:13649

向TA提问 私信TA
展开全部
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/html; charset=utf-8″ />
<title>JS获取CSS属性值</title>
<style type=”text/css”>
<!–
.ss{color:#cdcdcd;}
–>
</style>
</head>

<body>
<div id=”css88″ class=”ss” style=”width:200px; height:200px; background:#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/html; charset=utf-8″ />
<title>S获取CSS属性值</title>

<style type=”text/css”>
<!–
.ss{background:blue; color:#cdcdcd; width: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];
}
悄悄de爱上
2015-10-15 · TA获得超过2050个赞
知道小有建树答主
回答量:597
采纳率:66%
帮助的人:342万
展开全部

你得先抓取到某个应用css属性的对象,然后调用。

举个例子比较好说明。

比如以下的html代码:

======================================

<style type="text/css">
#testDiv{
    width:1920px;
    height:1080px;
    background-color:#ff2626;
    position:absolute;
    top:0px;
    left:0px;
    }
</style>
<div id="testDiv"></div>

=======================================

然后用getElementById("testDiv").style来获取CSS,比如:

=======================================

//获取css的宽度
var divWidth = document.getElementById("testDiv").style.width;
//获取css高度
var divHeigh = document.getElementById("testDiv").style.height;
//获取css背景色
var divBgColor = document.getElementById("testDiv").style.backgroundColor;

=======================================

另外:获取的宽度和高度都是字符,如果要将宽度高度变成数值,可以这么用:

var divWidthInt = parseInt(divWidth);
var divHeightInt = parseInt(divHeight);
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
遥远的寺
2010-12-15
知道答主
回答量:41
采纳率:0%
帮助的人:12.8万
展开全部
这个是获取不到的,除非<div style="color:red;font-size:12px;"> 这样的内样式才可以得到。
document.getElementByTagName('h-table').style.cssText
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式