CSS仅动态尺寸工具提示

时间:2019-05-04 22:21:20

标签: html css css3 tooltip

我想我已经接近了,但是我正在努力使工具提示完全按我的意愿工作。我有一个动态构建的HTML表,并且我想提供有关TD内容的工具提示。为了性能,它必须完全是CSS(而不是基于javascript或事件)。我希望工具提示在悬停时出现在TD的上方和中心,并在下方具有箭头。我已经做到了,但是我的问题是工具提示的内容有时可能是几行,从而增加了工具提示的高度。发生这种情况时,工具提示仍位于TD的中心,但不再位于其上方,它已向下移动。无论高度如何,我如何拥有一个始终在TD上方相同数量的工具提示。请帮忙。

html示例td:

<td>
    <div class="tooltip">
       <span>My Tooltip Text</span>
       Text in the TD
    </div>
</td>

我的CSS:

.tooltip span
{
    display: none;
    color: #000;
    text-decoration: none;
}

.tooltip:hover span
{
    display: block;
    position: absolute;
    background-color: #292929;
    margin: -2.8em -1em;
    color: white;
    padding: 0.5rem 1rem;
    border-radius: 4px;
    white-space: pre-line;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    text-align: left;
}

.tooltip:hover span::after
{
    top: 100%;
    left: 50%;
    border: solid transparent;
    content: '';
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border-top: 8px solid #292929;
    border-right: 8px solid transparent;
    border-left: 8px solid transparent;
    border-width: 10px;
    margin-left: -40px;
}

1 个答案:

答案 0 :(得分:1)

例如

@keyframes pulse {
  0% {
    opacity: .5;
    transform: translate(-50%, -100%) scale(.5); 
  }
  50%{
   opacity: 1;
   transform: translate(-50%, -100%) scale(1.2);
  }
  100% {
     transform: translate(-50%, -100%) scale(1);
  }
}

.tooltip span
{
    color: #000;
    text-decoration: none;
    transform: translate(-50%, -100%) scale(.5); 
    position: absolute;
    background-color: #292929;
    color: white;
    padding: 0.5rem 1rem;
    border-radius: 4px;
    font-size: 1rem;
    font-weight: 400;
    text-align: center;
    box-shadow: 0 0 4px 2px rgba(0,0,0,.2);
    width: max-content;
    max-width: 200px;
    top:0;
    left:50%;
    margin-top: -18px;
    visibility: hidden;
    opacity: 0;
}
.tooltip:hover{
  position: relative;
}
.tooltip:hover span
{
    opacity: 1;
    visibility: visible;
    transform: translate(-50%, -100%) scale(1);
    animation: pulse 1s;
}

.tooltip:hover span::after
{
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: solid transparent;
    content: '';
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border-top: 8px solid #292929;
    border-right: 8px solid transparent;
    border-left: 8px solid transparent;
    border-width: 10px;
}
<br>
<br>

<br>
<br>

<table border="1">
  <tr>
    <td>Hello</td>
    <td>
      <div class="tooltip">
         <span>My Tooltip Text</span>
         Cool text
      </div>
    </td>
    <td>
       <div class="tooltip">
         <span>Lorem ipsum dolor sit amet, consectetur adipiscing elit</span>
         Long text
      </div>
    </td>
  </tr>
</table>