首页 > 解决方案 > 在可滚动菜单栏上完全显示工具提示的解决方案

问题描述

在此处输入图像描述

我正在尝试制作一个下拉菜单栏,如果我将鼠标悬停在项目工具提示上,则会显示一些文本。

我得到了结果 A,我希望得到像 B 这样的结果,其中工具提示没有被下拉菜单覆盖一半。

我假设由于我的 span 元素位于锚元素内,因此它不可能从下拉菜单中弹出,或者可能是由于溢出属性,但我不确定如何修复或更改我的为了实现B的代码,我也不想增加下拉菜单的宽度来实现这一点,也就是说我不希望工具提示文本受到下拉菜单的限制。

有没有一个方向可以实现我的要求?

代码如下:

HTML

<ul id='menu'>
<li>choose
    <ul>
      <li><a class="tooltip" href="">a<span class="tooltiptext">this is a</span></a></li>
      <li><a class="tooltip" href="">b<span class="tooltiptext">this is b</span></a></li>
      <li><a class="tooltip" href="">c<span class="tooltiptext">this is c</span></a></li>
      <li><a class="tooltip" href="">d<span class="tooltiptext">this is d</span></a></li>
    </ul>
</li>

CSS

#menu > li {
    display:inline-block;
    border:1px solid grey;
    position:relative;
}
#menu li ul {
    position:absolute;
    border:1px solid grey;
    list-style-type: none;
    max-height:0;
    overflow:hidden;
}
#menu li:hover ul {
    overflow-y:scroll;
    overflow-x:hidden;
    max-height:150px;
}
.tooltip {
    position: relative;
    display: inline-block;
}
.tooltip .tooltiptext {
    visibility: hidden;
    width: 120px;
    background-color: #555;
    color: #fff;
    text-align: center;
    padding: 5px 0;
    border-radius: 6px;
    position: absolute;
    z-index: 1;
    bottom: 125%;
    left: 50%;
    margin-left: -60px;
}
.tooltip:hover .tooltiptext {
    visibility: visible;
    opacity: 1;
}

标签: htmlcsstooltip

解决方案


只需在 CSS 中做一点小改动

  #menu li:hover ul{
  overflow: visible;
  max-height:150px;
}

如上所示,您的问题是由于溢出值引起的。这是我的jsfiddle。这是关于溢出值w3schoolMDN的小文档。


推荐阅读