如何在CSS中使用一个元素创建工具提示

时间:2013-09-29 17:57:28

标签: jquery css tooltip

我有一个用3个元素和一个包装器

创建的工具提示

HTML:

<div class="tooltip-wrapper" style="position: relative;">
    <a href="https://twitter.com/jcubic" title="" rel="Twitter">
        <img src="http://images.jcubic.pl/jcubic/profile-twitter.png">
    </a>
    <div class="tooltip" style="top: -34px; left: -18px; display: block; opacity: 0.9648882429441257;">
        <div class="box">Twitter</div>
        <div class="arrow" style="border-left-width: 5px; border-right-width: 5px; border-top-width: 5px;"></div>
    </div>
</div>

内联样式由javascript(jQuery插件)创建。

和css:

.tooltip {
    display: none;
    position: absolute;
    z-index: 100;
}
.tooltip-wrapper .box {
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    background: #b72100;
    padding: 5px 10px;
    display: inline-block;
    text-align: center;
}
.tooltip-wrapper .arrow {
    width: 0; 
    height: 0; 
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;    
    border-top: 5px solid #b72100;
    margin: auto;
}

是否仅使用一个元素和css伪元素来创建工具提示:在箭头之后?

<div class="tooltip">Twitter</div>

您可以看到演示on my website(个人资料图标)。

我尝试将.tooltip.box样式合并,并从tooltip:after { content: ''; }创建.arrow,但样式不起作用。

1 个答案:

答案 0 :(得分:2)

是的,这是可能的。

定位.box亲戚和:after绝对。

HTML:

<div class="tooltip-wrapper" style="position: relative;">
    <a href="https://twitter.com/jcubic" title="" rel="Twitter">
        <img src="http://images.jcubic.pl/jcubic/profile-twitter.png" />
    </a>
    <div class="tooltip" style="top: -34px; left: -18px; display: block; opacity: 0.9648882429441257;">
        <div class="box">Twitter</div>
    </div>
</div>

CSS:

.tooltip-wrapper .box {
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    background: #b72100;
    padding: 5px 10px;
    display: inline-block;
    text-align: center;
    position: relative; /* added this line */
}
.tooltip-wrapper .box:after {
    content: '';
    width: 0; 
    height: 0; 
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;    
    border-top: 5px solid #b72100;
    position: absolute;
    bottom: -5px;
    left: 50%;
    margin-left: -3px;    
}

同时检查此demo