javascript - div,从javascript获取css属性

标签 javascript html css

嘿,我想从 javascript 更改一些 css 属性

但我无法访问该 div 的 css 值

这是我的 css 文件中的内容

#sidebar {
float: left;
width: 160px;
padding: 25px 10px 0 20px;
}

#sidebar ul {
margin: 0;
padding: 0;
list-style: none;
}

这是我的那个div的html代码

 <div id="sidebar">
     <%@ include file="some_page.jsp" %>
 </div>

这是我在某些点击事件上的 javascript 代码

var element = document.getElementById('sidebar');
alert(element.style.length); //Will alert 0
alert(element.style.width);//Empty alert box

我想改变宽度属性, 你能帮帮我吗?

谢谢

最佳答案

尝试此代码,基于此处的代码:http://www.quirksmode.org/dom/getstyles.html

var sidebarWidth = getStyle('sidebar','width');

function getStyle(el,styleProp) {
    el = document.getElementById(el);
    return (el.currentStyle)
        ? el.currentStyle[styleProp] 
        : (window.getComputedStyle)
             ? document.defaultView.getComputedStyle(el,null)
                                    .getPropertyValue(styleProp)
             : 'unknown';
}​

编辑:

为了提供代码的可读性更高的版本,这更接近于 quirksmode 版本。我更改了它以去除不必要的变量。

var sidebarWidth = getStyle('sidebar','width');

function getStyle(el,styleProp) {
    el = document.getElementById(el);
    var result;
    if(el.currentStyle) {
        result = el.currentStyle[styleProp];
    } else if (window.getComputedStyle) {
        result = document.defaultView.getComputedStyle(el,null)
                                    .getPropertyValue(styleProp);
    } else {
        result = 'unknown';
    }
    return result;
}​

关于javascript - div,从javascript获取css属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3505320/

相关文章:

html - 背景图100%固定位置问题

html - 通过悬停过渡增加导航项的宽度

css - 第一行有 2 个感冒,然后使用 css 网格在每行中有 3 列

javascript - 从 jQuery GET 请求执行脚本

javascript - 我的私有(private)消息不适用于 socket.io

javascript - 如何在pentaho中将外部javascript变量作为sql参数传递?

CSS div 表和文本溢出 :ellipsis

javascript - 仅当部分不是视口(viewport)时,如何使图像贴在底部?

javascript - 使用 jQuery 动画(即 drop)时,有没有一种方法可以平滑附近的文本过渡?

Css 溢出不起作用