如何用CSS定位div中的h1

时间:2017-08-22 15:37:40

标签: html css

我只是在制作一个模拟网站,试图学习代码,我在div中定位h1元素时遇到了问题。另一个问题是我的横幅比顶部黑色菜单栏更向右流动,导致用户必须向右滚动。我不明白为什么会这样。会爱所有的帮助!谢谢!

<!DOCTYPE html>

<html lang="eng">

<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" type="text/css" href="css.css">
    <title> Sankyeat Kumar | Web Developer </title>
</head>

<body>
    <div id="menu">
        <div><a href="index.html">Home</a></div>
        <div><a href="portfolio.html">Portfolio</a></div>
        <div><a href="blog.html">Blog</a></div>
        <div><a href="contact.html">Contact</a></div>
    </div>

    <div id="banner">
        <div id="heading">
            <h1> Web Developer</h1>
            <h4>London Based Web Developer For hire</h4>
        </div>          
    </div>



    <h2> Services </h2>




</body>



</html>


body {
  margin:0px;
  padding:0px;
}

@media screen and (min-width: 480px) {

#menu {
display:flex;
background-color: black;
max-height:50px;
max-width:100%;

}

#menu div {
margin: 0 auto;
color: ##678F99;
padding:10px;
}

#menu div a {
color:white;    
text-decoration: none;
font-size: 1.5em;
font-family: Tahoma, Geneva, sans-serif;
}

#menu div a:hover {
text-decoration: underline;
}

#banner {
height:100vh;
width:100vw;
background-image: url('images/mountains.jpg');
background-size: 100% 100%;
background-repeat: no-repeat;
display: flex;
flex-direction: column;
flex-wrap: wrap;
justify-content: center;
align-items: center;

}

#heading {
display: flex;
flex-direction: column;
flex-wrap: wrap;
justify-content: center;
align-items: center;
{

 #banner #heading h1 {
 color: white;

 }


}

2 个答案:

答案 0 :(得分:1)

for targeting h1 you can use this-
you had a mistake on closing tag of css #heading

#banner {
  width:100%;
 /*100vw is getting a bit larger than screen because scrool bar on the right racking a little space from your screen*/

  width:calc(100vw - 17px);
 /* you can use this also. it minuses the scrolls width from screen width.*/
}

body {
  margin:0px;
  padding:0px;
}

@media screen and (min-width: 480px) {

#menu {
display:flex;
background-color: black;
max-height:50px;
max-width:100%;

}

#menu div {
margin: 0 auto;
color: ##678F99;
padding:10px;
}

#menu div a {
color:white;    
text-decoration: none;
font-size: 1.5em;
font-family: Tahoma, Geneva, sans-serif;
}

#menu div a:hover {
text-decoration: underline;
}

#banner {
height:100vh;
width:100%;
width:calc(100vw - 17px);
background-image: url('images/mountains.jpg');
background-size: 100% 100%;
background-repeat: no-repeat;
display: flex;
flex-direction: column;
flex-wrap: wrap;
justify-content: center;
align-items: center;

}

#heading {
display: flex;
flex-direction: column;
flex-wrap: wrap;
justify-content: center;
align-items: center;
}

 #banner #heading h1 {
 color: red;
}

}
<!DOCTYPE html>

<html lang="eng">

<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" type="text/css" href="css.css">
    <title> Sankyeat Kumar | Web Developer </title>
</head>

<body>
    <div id="menu">
        <div><a href="index.html">Home</a></div>
        <div><a href="portfolio.html">Portfolio</a></div>
        <div><a href="blog.html">Blog</a></div>
        <div><a href="contact.html">Contact</a></div>
    </div>

    <div id="banner">
        <div id="heading">
            <h1> Web Developer</h1>
            <h4>London Based Web Developer For hire</h4>
        </div>          
    </div>



    <h2> Services </h2>




</body>



</html>

答案 1 :(得分:0)

如果您想定位h1内的div元素,可以使用以下内容:

div > h1 {
  //css goes here
}

这将定位作为<div>

的直接子项的元素