찾다

 >  Q&A  >  본문

html5 - CSS浮动问题 位置偏移了?

css代码如下:

.nav{
    width: 1000px;
    height: 40px;
    background: url("../images/nav_bg.jpg") repeat-x;
    margin: 0 auto;
}


.nav .nav_left{
    float: left;
}

.nav_left li{
    list-style-type: none;
    float: left;
    width: 100px;
    line-height: 40px;
    text-align: center;
}

.nav_left a{
    text-decoration: none;
    color: white;
    font-size: 16px;
    font-family: 微软雅黑;
}

.nav .nav_right{
    float: right;
}

html代码如下:

<p class="nav">
            <p class="nav_left">
                    <ul>
                        <li><a href="#">首页</a></li>
                        <li><a href="#">关于慕课</a></li>
                        <li><a href="#">新闻动态</a></li>
                        <li><a href="#">课程中心</a></li>
                        <li><a href="#">在线课程</a></li>
                        <li><a href="#">人才招聘</a></li>
                    </ul>
                </p>
            <p class="nav_right">
                    <input type="text">
                </p>
        </p>    

效果:

li的flot设置成了left
效果不应该是靠左么 为什么会出现在灰色条的中间呢?
求解

高洛峰高洛峰2826일 전729

모든 응답(3)나는 대답할 것이다

  • ringa_lee

    ringa_lee2017-04-17 14:01:13

    检查这个logo区域的高度是否异常,有可能就相差几个像素,导致logo超出了上面白色的header区域,
    底下的nav >li float left的时候位置不够就靠右了。

    회신하다
    0
  • 怪我咯

    怪我咯2017-04-17 14:01:13

    右键,审查下就好...
    猜测是ul的默认样式带padding的问题

    회신하다
    0
  • ringa_lee

    ringa_lee2017-04-17 14:01:13

    因为你的.nav样式中设置的margin是 margin: 0 auto; 导致容器自动调整左右距离,默认两边距离一直,内容区居中显示。还有一个地方需要注意,就是浏览器的对ul/li的默认样式,如chrome:

    效果图,.nav 容器已经将子节点居中了:

    회신하다
    0
  • 취소회신하다