CSS:UL 导航 - 悬停时,背景颜色错误

标签 css html-lists navigationbar

悬停时,背景颜色似乎超出了我的导航项“框”。我试过调整一切。这是我的 CSS 和 HTML...

<div id="menuTop">

 <ul id="menuOne" class="menuHoriz">
    <li><a href="index.html">home</a></li>
    <li><a href="communication.html">about us</a></li>
    <li><a href="about.html">services</a></li>
    <li><a href="help.html">samples</a></li>
    <li><a href="contact.html">contact</a></li>
</ul>

</div>

#menuTop {
clear: both;
padding-top: 18px;
height: 55px;
font-size: 12pt;
background-color: #000;
 }

#menuTop ul, #menuTop li {
margin: 0;
padding: 4px 0 0 0;
}

#menuTop ul {
list-style-type: none;
}

#menuTop li {
display: block;
background-color: #3C87D1;
text-align: center;
width: 197px;
height: 30px;
margin: 0 0px 0 0;
padding: 4px 0 0 0;
border: 1px solid #2A5E92;
}

#menuTop a {
display: block;
margin: 0;
padding: 4px 0 0 0;
}

#menuTop a:link, #menuTop a:visited {
width: 197px;
height: 30px;
padding: 4px 0 0 0;
margin: 0;
font-family: 'Trebuchet MS', Helvetica, sans-serif;
color: #fff;
text-decoration: none;
}

#menuTop a:hover {
width: 197px;
height: 30px;
padding: 4px 0 0 0;
margin: 0;
color: #fff;
background-color: #5F9FFF;
}

ul.menuHoriz li {
float: left;
}

最佳答案

我从您的样式表中删除了不需要的/双重定义并修复了错误。

* {
    margin: 0;
    padding: 0
}
#menuTop {
    font: 12pt 'Trebuchet MS', Helvetica, sans-serif;
    padding-top: 18px;
    height: 55px;
    background: #000
}
#menuTop ul {
    padding-top: 4px;
    list-style: none
}
#menuTop li {
    background: #3C87D1;
    border: 1px solid #2A5E92;
    text-align: center
}
#menuTop a {
    display: block;
    width: 197px;
    line-height: 30px
}
#menuTop a:link, #menuTop a:visited {
    color: #fff;
    text-decoration: none
}
#menuTop a:hover {
    background-color: #5F9FFF
}
ul.menuHoriz li {
    float: left
}

这里有一些注意事项:

  • 在设计布局之前,使用 * 将所有元素的边距和填充设置为零会很方便。
  • 仅将菜单项的宽度和高度设置为 a 元素(最嵌套的元素)。周围的 li 元素将采用相同的大小。还可以使用 line-height 而不是 height 因为它会自动使您的文本垂直居中。
  • 不要在 :link:visited:hover:active 中重新定义样式(对于例如尺寸和字体)。它为浏览器提供了不必要的计算。

关于CSS:UL 导航 - 悬停时,背景颜色错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6145135/

相关文章:

html - 创建导航 - 内联 block 还是 float ?

javascript - 为什么我的网站导航在谷歌浏览器中消失了?

android - 如何在 Android 应用中隐藏导航栏?

ios - 移动 Safari : change background color of picker view (select)

jquery - 我需要使用 CSS 和 jQuery 使输入字段溢出 td 而不更改其位置或 tds 宽度

html - 禁用水平滚动

javascript - 如何将内容与列表放在同一行?

html - li 上的“自动换行”而不是单个单词

swift - 尝试在 Swift 中通过 Alpha 隐藏 SearchBar

javascript - 使用 jQuery 的可扩展菜单 - 动画