【问题标题】:Why does my header and navigation go below my hero image?为什么我的标题和导航位于我的英雄形象下方?
【发布时间】:2015-04-09 22:05:17
【问题描述】:

为什么我的标题和导航位于我的英雄图片下方? 每当我增加图像上文本的大小时,导航和标题会进一步下降。如果我摆脱文本的大小,它会回到我想要的位置。 这是我的html和css。

HTML

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>Amanda Farrington</title>
<link rel="stylesheet" href="css/demo.css" />
<link href='http://fonts.googleapis.com/css?family=Roboto:400,300,500' rel='stylesheet' type='text/css'>
</head>

<body>


    <div id="header">
        <div id="leftHeader">
        <img src="assets/logo2.jpg" alt="Logo" style="width:65px;height:65px">
        <h1>Amanda Farrington</h1>
    </div>
        <div id="nav">

      <ul>
        <li><a href="index.html">About</a></li>
        <li><a href="tips.html">Work</a></li>
        <li><a href="mentally.html">Contact</a></li>
      </ul>

        </div>



    </div>



    <div id="hero">
        <div id="heroImage">
        <img src="assets/trees.jpg" alt="trees" style="width:100%;height:10%">
        </div>

        <div id="overlay">
        <h2>Amanda Farrington</h2>
        </div>
    </div>

</body>
</html>

CSS

body {
  margin: 0px;
  padding: 0px;
  height: 100%;
  background: white;

}

#header {
  color: #D7DADB;
  font-family: 'Roboto', sans-serif;
  font-weight: 300;
  font-size : 15px;
  text-align: left;
  width: 97%;
  margin:0;
  padding-left: 3em;
  float: left;
  background: white;
  height: 10%;

}

#leftHeader
{
}

#header img
{
    float: left;
    padding-left: 3em;
}

h1{
width: 9em;
float: left;
padding-left: 0.5em;
color: #45CCCC;
padding-bottom: 1px;
}



#nav {
  width: 40%;
  margin:0;
  padding:0;
  text-align: right;
  color: red;
  font-size:20px;
  float: right;
  padding-right: 2em;


}

#nav ul {
  padding: 1px;
}

#nav li {
  display: inline;
  padding: 38px;
}

#nav li a {
  color: #2C3E50;
  text-decoration: none;
}

#nav li a:hover {
  color: #45CCCC;
}

#hero{
    width: 100%;
    height: 30em;
}

#heroImage
{
    top: 12%;
    width: 100%;
    z-index: 1;
    position: absolute;
}

#overlay{
    width: 30em;
    top: 90%;
    margin-left: 30%;
    z-index: 2;
    position: relative;
}

h2{
    width: 9em;
    position: relative;
    font-family: 'Roboto', sans-serif;
    font-weight: 300;
    font-size: 60px;
    float: center;
    color: white;
    opacity: 1.0;
    text-shadow: 2px 2px 3px rgba(0,0,0,0.6);
}

【问题讨论】:

    标签: css header navigation


    【解决方案1】:

    这是因为你的#heroImage div 中的position: absolute;(如果我理解,你想要什么)

    【讨论】:

    • 如果我希望图像是静态的并位于 div“标题”的正下方,我应该将其更改为什么?我还希望 div “叠加层”位于图像之上。
    • 添加到#header {position: relative;}#hero {position: relative},然后您将position:absolute 留在#heroImage
    • 这有帮助!但是如果你把背景变成红色的 div “header”,它上面会有一个很大的空白区域。是什么原因造成的?
    • 或许可以试试#heroImage {top: 12%;}
    猜你喜欢
    • 2015-03-01
    • 2021-08-31
    • 2021-07-15
    • 2020-10-20
    • 1970-01-01
    • 2014-05-21
    • 2016-07-24
    • 2021-02-10
    • 2023-04-07
    相关资源
    最近更新 更多