为什么这两个div被轻微推下来?

时间:2010-10-14 03:41:54

标签: css html

我的HTML很简单,我有一个包含所有内容的内容区域,我想要三个columsn。其中两个必须有固定的宽度,主要内容区域应该是灵活的。

我想知道我做错了什么 - 编辑这里是完整的代码抱歉,如果它有点长!:

<%@ Master Language="C#" Inherits="System.Web.Mvc.ViewMasterPage" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title><asp:ContentPlaceHolder ID="TitleContent" runat="server" /></title>
    <link href="../../Content/Site.css" rel="stylesheet" type="text/css" />
</head>

<body>    
    <div id="header">
        <img src="../../Content/images/cumaviLogo.png" alt="Cumavi.com - Compras y ventas online en Bolivia!" />    
        <ul id="topuserbar">
            <li>Bienvenidos, <span class="userSalute">Sergio!</span></li>
            <li><a href="#">Mis Anuncios</a></li>
            <li><a href="#">Perfil</a></li>
            <li><a href="#">Ayuda</a><img class="helpicon" src="../../Content/images/helpIcon.png" alt="Help icon." width="20" height="20"/></li>
            <li><a href="#">Cerrar Sesion</a></li>
        </ul>
    </div>
    <div id="headershadow">
    </div>
    <div id="body">
        <div id="leftnavigation"></div>
        <div id="contentarea"></div>
        <div id="advertisingarea">
        </div>
    </div>


    <asp:ContentPlaceHolder ID="MainContent" runat="server" />
</body>
</html>


body
{
    background-image: url('images/test.png');
    background-repeat:repeat;
    margin:0;
    padding:0;
}

#header
{
    background-image: url('images/headerBackground.png');
    background-repeat:repeat;
    width:auto;
}

#headershadow
{
    background-color:Black;
    min-height:2px;
}

#topuserbar
{
    font-family:Georgia;
    font-size:large;    
    float:right;
    margin-top:35px;  
    margin-right:15px;
}

#topuserbar ul
{
}

#topuserbar li
{
    display:inline;
    margin-left:10px;
    color:#fff;
}

#topuserbar .helpicon
{
    position:relative;
    top:4px;
    left:2px;
}

#topuserbar a
{
    color:White;
}

#topuserbar a:hover
{
    color:Yellow;
}

/*****************BODY AREA*******************/

#body
{
    border: 1px solid red;
    min-height:800px;
    width:960px;
}

#leftnavigation
{
    border: 1px solid green;
    min-height:500px;
    float:left;
    width:190px;
}

#contentarea
{
    border:1px solid blue;
    min-height:500px;
    float:left;
    width:590px;
}

#advertisingarea
{
    border:1px solid orange;
    width:150px;
    float:left;
    min-height:500px;
}

alt text

4 个答案:

答案 0 :(得分:0)

可能是因为累积的1像素边界?

答案 1 :(得分:0)

塞尔吉奥,我不确定这是否会成为答案,但尝试用轮廓代替边界。边框具有像素宽度,而轮廓则没有。这可能会解决您的问题。

CSS用法:outline{1px solid red;}

答案 2 :(得分:0)

可能是:

#headershadow
{
    background-color:Black;
    min-height:2px;

答案 3 :(得分:0)

<ul id=topuserbar>上方/下方的高度和填充正在向下推动第二和第三个div。 将height:43px;(或更高)添加到#header以将其下方的元素向下推,这将排列3个div div。

Firebug是你的朋友!