html - 为什么子菜单标签需要父级 li css?

标签 html css

所以我正在创建一个菜单,子菜单标签采用父li菜单CSS - 颜色,字体大小,字体粗细等。我该如何解决这个问题?好吧,我已经为 li 元素设置了与子菜单 a 元素相同的大小和重量,但是为父 li 元素设置颜色并不能解决问题,它仍然与 href 应该具有的不同。

代码 -

#top-menu-wrapper #menu {
  float: left;
  margin-left: 45px;
  height: 81px;
  width: auto;
}

#top-menu-wrapper #menu ul {
  list-style: none;
  padding: 0;
  width: auto;
  margin: 0;
  margin-top: 30px;
  float: left; 
}

#top-menu-wrapper #menu ul li {
  margin: 0;
  padding: 0;
  display: inline;
  margin-left: 20px;
  float: left;
  background-image: url('../images/down.png');
  background-repeat: no-repeat;
  padding-right: 10px;
  background-position: right 9px;
  height: 50px;
  font-weight: bold;
  font-size: 12px;
}   

#top-menu-wrapper #menu ul li span {
  font-size: 9px;
  color: #b9e5f9;  
}

#top-menu-wrapper #menu ul li:hover span {
  padding-bottom: 5px;
  border-bottom: 2px solid #b9e5f9;
}

#top-menu-wrapper #menu ul li:hover{
  margin: 0;
  padding: 0;
  display: inline;
  margin-left: 20px;
  float: left;
  background-image: url('../images/down-hover.png');
  background-repeat: no-repeat;
  padding-right: 10px;
  background-position: right 9px;
  height: 50px;  
}   

#top-menu-wrapper #menu ul li:hover span {
  font-size: 9px;
  color: #5e5e5e;
}

#top-menu-wrapper #menu ul li a.menu {
  color: #5e5e5e;
  font-weight: bold;
  font-size: 15px;
  text-decoration: none;   
}

#top-menu-wrapper #menu ul li a.menu:hover {
  color: #b9e5f9;
  font-weight: bold;
  font-size: 15px;
  text-decoration: none;      
}

#top-menu-wrapper #menu ul li ul {
  display: none;    
} 

#top-menu-wrapper #menu ul li:hover ul {
  display: block;
  position: absolute;
  width: 170px;
  margin:0;
  margin-top: 17px;
  padding:0;
  height: 100px;
  background: url('../images/menu-dropdown-bg.png');
  z-index: 200;
  behavior: url(ie-css3.htc);
  border-bottom-right-radius:5px;
  -webkit-border-bottom-right-radius:5px;
  -moz-border-bottom-right-radius: 5px;
  -khtml-border-bottom-right-radius: 5px;
  border-bottom-left-radius:5px;
  -webkit-border-bottom-left-radius:5px;
  -moz-border-bottom-left-radius: 5px;
  -khtml-border-bottom-left-radius: 5px;  
} 

#top-menu-wrapper #menu ul li:hover ul li {
  width: 150px;
  height: 20px;
  border-bottom: 1px solid #eeeeee;
  padding: 0px;
  margin: 0px;
  margin-left: 10px;
  background: none;
  padding-top: 7px;
  padding-bottom: 5px;
}

#top-menu-wrapper #menu ul li:hover ul li a.submenu {
  color: #5e5e5e;
  text-decoration: none;
  padding-left: 10px;
  font-size: 12px;
  font-weight: bold;
}

#top-menu-wrapper #menu ul li:hover ul li a.submenu:hover {
  color: #b9e5f9;
  text-decoration: none;
  padding-left: 10px;
  font-size: 12px;
  font-weight: bold;
}

HTML -

     <div id="menu">
       <ul>
         <li style="background: none;"><a href="#" class="menu">Home</a><br /><span>To first page</span></li>
         <li><a href="#" class="menu">Services</a><br /><span>Various Hands</span>
    <ul>
      <li><a href="#" class="submenu">Features</a></li>
    </ul>
   </li>
         <li><a href="#" class="menu">Portfolio</a><br /><span>Our Works</span></li>
         <li><a href="#" class="menu">Journal</a><br /><span>Our Stories</span></li>
         <li><a href="#" class="menu">Contact Us</a><br /><span>Reach us now</span></li>
       </ul>
     </div>

最佳答案

我学到的一个重要教训是使用基于列表的菜单:不要设置 LI 标签的样式(定位和显示除外),将所有样式放在 A 标签上并使用 显示: block

关于html - 为什么子菜单标签需要父级 li css?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9215699/

相关文章:

html - 如何将在线字体链接转换为本地字体链接?

javascript - 将选定/保存的值(来自数据库)设置/显示到选择框以进行编辑

html - 正方形列中的中心图像

ios - 在 iOS 中的 'next' 或 'previous' 虚拟键盘上

jquery - Foundation Zurb 下拉菜单不起作用

html - 如何为 <td> 元素设置 flex-direction

jquery - css水平下拉定位

javascript - 如何更改 Smoke.js 中烟雾的颜色?

html - CSS 样式 WordPress 小部件

jquery - 无论如何检查容器高度并相应地更改 CSS?