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
效果不应该是靠左么 为什么会出现在灰色条的中间呢?
求解
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
检查这个logo区域的高度是否异常,有可能就相差几个像素,导致logo超出了上面白色的header区域,
底下的nav >li float left的时候位置不够就靠右了。
右键,审查下就好...
猜测是ul的默认样式带padding的问题
因为你的.nav样式中设置的margin是

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

.nav容器已经将子节点居中了: