li 内的 div 不扩展

Posted

技术标签:

【中文标题】li 内的 div 不扩展【英文标题】:Div within li not expanding 【发布时间】:2013-01-04 12:46:07 【问题描述】:

我有一个使用无序列表构建的水平菜单。将鼠标悬停在其中一个列表项上时,将显示一个包含在 div 中的子菜单。在内容正确显示的子菜单中,div 本身被限制为父列表项的宽度。这会导致内容溢出到 div 的右侧。我怎样才能使 div 随内容扩展。

html & CSS on JSFiddle

HTML:

<div>
<ul class="menu">
  <li class="menuTab menuTabFirst">
    Menu Bar Item 1
    <div class="menuDropDown">
      <h2><a href="#">Menu Heading Goes Here</a></h2>
      <ul>
        <li><a href="#">Menu Item 1 Goes Here</a></li>
        <li><a href="#">Menu Item 2 Goes Here</a></li>
        <li><a href="#">Menu Item 3 Goes Here</a></li>
        <li><a href="#">Menu Item 4 Goes Here</a></li>
      </ul>

      <h2><a href="#">Menu Heading Goes Here</a></h2>
      <ul>
        <li><a href="#">Menu Item 1 Goes Here</a></li>
        <li><a href="#">Menu Item 2 Goes Here</a></li>
        <li><a href="#">Menu Item 3 Goes Here</a></li>
        <li><a href="#">Menu Item 4 Goes Here</a></li>
      </ul>
    </div>
  </li>

  <li class="menuTab">
    Menu Bar Item 2
    <div class="menuDropDown">
      <h2><a href="#">Menu Heading Goes Here</a></h2>
      <ul>
        <li><a href="#">Menu Item 1 Goes Here</a></li>
        <li><a href="#">Menu Item 2 Goes Here</a></li>
        <li><a href="#">Menu Item 3 Goes Here</a></li>
        <li><a href="#">Menu Item 4 Goes Here</a></li>
      </ul>
    </div>
  </li>
</ul>
</div>

CSS:

.menu 
    list-style-type: none;
    border-spacing:3px 0px;
    padding: 0px;
    display: table;
    margin: 5px 0px 0px;
    text-align:center;
    height: 26px;
    width: 300px;

.menuTab 
    background-color: #D2DCE0;
    display: table-cell;
    position: relative;
    margin:0px 5px 0px 0px;
    padding:6px 0px;
    font-size: 15px;
    width: auto;
    cursor: default;
    border-bottom: 0px;
    color: #002F68;

.menuTab:hover 
    background-color:#93B4D6;
    color: white;

.menuTab:hover .menuDropDown 
    left:0px; /* Shows the dropdown div */

.menuDropDown 
    background-color:#EBECEF;
    border:1px solid #6798CF;
    position: absolute;
    left:-999em; /* Hides the dropdown until menuTab mouseover */
    margin-top: 5px;
    z-index: 1;
    display: block;

.menuDropDown ul 
    list-style-type: none;
    margin:0px;
    padding:0px;
    margin-left: 20px;
    margin-bottom: 20px;
    text-align: left;

.menuDropDown h2 
    font-size:14px;
    margin-left: 18px;
    margin-bottom: 5px;
    font-weight: normal;
    text-align: left;

.menuDropDown h2 a 
    color: black;

.menuDropDown li 
    font-size:14px;
    padding:0px;
    margin-left: 10px;

.menuDropDown li a 

    
.menuDropDown li:hover 
        background-color: #EBECEF;

.menuLastTab 
    margin-right: 0px;
​

【问题讨论】:

【参考方案1】:

试试这个来正确定位子菜单:

.menuTab:hover .menuDropDown 
    left: inherit; /* Shows the dropdown div positioned properly */

这可以缩放菜单内的内容:

.menuDropDown ul 
    list-style-type: none;
    margin:0px;
    text-align: left;
    padding: 20px;

问候。

【讨论】:

以上是关于li 内的 div 不扩展的主要内容,如果未能解决你的问题,请参考以下文章

是否可以使用自定义模板创建可扩展的UI网格作为Ul li显示

jQuery查找并列出特定DIV中UL内的所有LI元素

将最后一个 li 扩展到 ul 的剩余宽度并右对齐

如何在不扩展边框的情况下填充 div?

在扩展 div 旁边停止 div 移动

悬停时,DIV 扩展并与其他对象重叠