【问题标题】:Tooltip with HTML content without JavaScript带有 HTML 内容但没有 JavaScript 的工具提示
【发布时间】:2013-06-27 18:58:17
【问题描述】:

当您将鼠标悬停在网页的特定区域时,有很多基于 JavaScript 的库会显示工具提示。有些相当简单,有些允许工具提示显示带有 CSS 样式的 HTML 内容。

但是有没有一种方法可以在不使用 JavaScript 的情况下显示样式化的工具提示?如果您只使用title 属性,则不会处理标签(例如foo<br />bar 不会产生换行符)。我正在寻找一种解决方案,它允许人们在不使用任何 JavaScript 的情况下显示样式化的 HTML 内容。

【问题讨论】:

  • 使用title属性。
  • @Nile:这行不通。例如,如果我放了“
    ”标签,工具提示显示“foo
    bar”,你懂我的意思吗?
  • 我也看不出反对票的意义所在。为什么关闭?不是 HTML 和 CSS 代码吗?我从谷歌来到这里想“大声笑,这不能做伙计......” - 但显然我错了。 :)
  • 这绝对是一个关于编程的问题——事实上,我很惊讶没有更多的人这样做:优雅的 CSS 使用:hover,而不是添加另一个 JavaScript 库到不断增长的堆...应该重新打开。向我 +1 以抵消那些(我只能想象)没有得到问题的人的反对票。
  • 感谢重新打开这个问题的模组! :-)

标签: html css tooltip


【解决方案1】:

我用css做了一个小例子

.hover {
  position: relative;
  top: 50px;
  left: 50px;
}

.tooltip {
  /* hide and position tooltip */
  top: -10px;
  background-color: black;
  color: white;
  border-radius: 5px;
  opacity: 0;
  position: absolute;
  -webkit-transition: opacity 0.5s;
  -moz-transition: opacity 0.5s;
  -ms-transition: opacity 0.5s;
  -o-transition: opacity 0.5s;
  transition: opacity 0.5s;
}

.hover:hover .tooltip {
  /* display tooltip on hover */
  opacity: 1;
}
<div class="hover">hover
  <div class="tooltip">asdadasd
  </div>
</div>

小提琴

http://jsfiddle.net/8gC3D/471/

【讨论】:

  • 请在您的答案中添加代码。小提琴总是很好地展示结果。
  • 这不太好用。如果您悬停.tooltip 而没有悬停.hover,则会出现工具提示。因此我建议添加visibility: hidden/visible 来避免这种情况。
  • @Kenneth_hj 你好,Kenneth,过渡效果是 CSS3,在旧版浏览器中它可以工作,只是没有过渡!
  • 我明白了...谢谢您的解释。但无论如何,visibility 的规则在 Chrome Win7 上对我不起作用...
  • @LukaszCzerwinski 是的,我注意到了,它曾经可以工作,但现在不行了!我删除了可见性,谢谢你的建议
【解决方案2】:

使用 title 属性:

&lt;a href="#" title="Tooltip here"&gt;Link&lt;/a&gt;

【讨论】:

  • 好主意,但它只会包含文本,而不是 OP 想要的 html 内容。
  • 在您悬停和显示内容之间也有很长的停顿。我想很多人会在它出现之前就继续前进,因为他们不知道等待。
【解决方案3】:

类似于 koningdavid,但适用于 display:none 和 block,并添加了额外的样式。

div.tooltip {
  position: relative;
  /*  DO NOT include below two lines, as they were added so that the text that
        is hovered over is offset from top of page*/
  top: 10em;
  left: 10em;
  /* if want hover over icon instead of text based, uncomment below */
  /*    background-image: url("../images/info_tooltip.svg");
            /!* width and height of svg *!/
            width: 16px;
            height: 16px;*/
}


/* hide tooltip */

div.tooltip span {
  display: none;
}


/* show and style tooltip */

div.tooltip:hover span {
  /* show tooltip */
  display: block;
  /* position relative to container div.tooltip */
  position: absolute;
  bottom: 1em;
  /* prettify */
  padding: 0.5em;
  color: #000000;
  background: #ebf4fb;
  border: 0.1em solid #b7ddf2;
  /* round the corners */
  border-radius: 0.5em;
  /* prevent too wide tooltip */
  max-width: 10em;
}
<div class="tooltip">
  hover_over_me
  <span>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec quis purus dui. Sed at orci. </span>
</div>

【讨论】:

  • 好点,您从 opacity:0 切换到 display:none 。否则,当您悬停在元素周围时,您会看到工具提示的奇怪效果,因为您将鼠标悬停在工具提示上,即使它不可见。
【解决方案4】:

这个很有意思,

仅 HTML 和 CSS

.help-tip {
  position: absolute;
  top: 18px;
  left: 18px;
  text-align: center;
  background-color: #BCDBEA;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  font-size: 14px;
  line-height: 26px;
  cursor: default;
}

.help-tip:before {
  content: '?';
  font-weight: bold;
  color: #fff;
}

.help-tip:hover span {
  display: block;
  transform-origin: 100% 0%;
  -webkit-animation: fadeIn 0.3s ease-in-out;
  animation: fadeIn 0.3s ease-in-out;
}

.help-tip span {
  display: none;
  text-align: left;
  background-color: #1E2021;
  padding: 5px;
  width: 200px;
  position: absolute;
  border-radius: 3px;
  box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.2);
  left: -4px;
  color: #FFF;
  font-size: 13px;
  line-height: 1.4;
}

.help-tip span:before {
  position: absolute;
  content: '';
  width: 0;
  height: 0;
  border: 6px solid transparent;
  border-bottom-color: #1E2021;
  left: 10px;
  top: -12px;
}

.help-tip span:after {
  width: 100%;
  height: 40px;
  content: '';
  position: absolute;
  top: -40px;
  left: 0;
}
<span class="help-tip">
    	<span > This is the inline help tip! </span>
</span>

【讨论】:

    【解决方案5】:

    纯 CSS:

    .app-tooltip {
      position: relative;
    }
    
    .app-tooltip:before {
      content: attr(data-title);
      background-color: rgba(97, 97, 97, 0.9);
      color: #fff;
      font-size: 12px;
      padding: 10px;
      position: absolute;
      bottom: -50px;
      opacity: 0;
      transition: all 0.4s ease;
      font-weight: 500;
      z-index: 2;
    }
    
    .app-tooltip:after {
      content: '';
      position: absolute;
      opacity: 0;
      left: 5px;
      bottom: -16px;
      border-style: solid;
      border-width: 0 10px 10px 10px;
      border-color: transparent transparent rgba(97, 97, 97, 0.9) transparent;
      transition: all 0.4s ease;
    }
    
    .app-tooltip:hover:after,
    .app-tooltip:hover:before {
      opacity: 1;
    }
    &lt;div href="#" class="app-tooltip" data-title="Your message here"&gt; Test here&lt;/div&gt;

    【讨论】:

    • 非常聪明:内容:attr(data-title);
    • 问题是关于在工具提示中显示 HTML 内容;您的答案显示文字内容。
    【解决方案6】:

    通过 css 实现的另一种类似方法:

    #img {  }
    #img:hover {visibility:hidden}
    #thistext {font-size:22px;color:white }
    #thistext:hover {color:black;}
    #hoverme {width:50px;height:50px;}
    
    #hoverme:hover { 
    background-color:green;
    position:absolute ;
    left:300px;
    top:100px;
    width:40%;
    height:20%;
    }
    &lt;p id="hoverme"&gt;&lt;img id="img" src="http://a.deviantart.net/avatars/l/o/lol-cat.jpg"&gt;&lt;/img&gt;&lt;span id="thistext"&gt;LOCATZ!!!!&lt;/span&gt;&lt;/p&gt;

    试试看:http://jsfiddle.net/FdBu7/

    这里有一些关于过渡和新方法的链接: http://www.w3schools.com/css3/css3_transitions.asp http://dev.opera.com/articles/view/css3-show-and-hide/

    【讨论】:

    • 它在 Chrome/Win7 上无法正常工作 - 图像闪烁/翻转
    【解决方案7】:

    您可以使用 title 属性,例如如果你想在文本上有一个工具提示,只需:

    &lt;span title="This is a Tooltip"&gt;This is a text&lt;/span&gt;

    【讨论】:

    • “好主意,但它只能保存文本,而不是 OP 想要的 html 内容。”
    【解决方案8】:

    这是我的解决方案:

    https://gist.github.com/BryanMoslo/808f7acb1dafcd049a1aebbeef8c2755

    该元素带有工具提示文本的“工具提示标题”属性,并在悬停时使用 CSS 显示,我更喜欢这种解决方案,因为我不必将工具提示文本包含为 HTML 元素!

    #HTML
    <button class="tooltip" tooltip-title="Save">Hover over me</button>
    
    #CSS
    
    body{
        padding: 50px;
    }
    .tooltip {
        position: relative;
    }
    
    .tooltip:before {
        content: attr(tooltip-title);
        min-width: 54px;
        background-color: #999999;
        color: #fff;
        font-size: 12px;
        border-radius: 4px;
        padding: 9px 0;
        position: absolute;
        top: -42px;
        left: 50%;
        margin-left: -27px;
        visibility: hidden;
        opacity: 0;
        transition: opacity 0.3s;
    }
    
    .tooltip:after {
        content: "";
        position: absolute;
        top: -9px;
        left: 50%;
        margin-left: -5px;
        border-width: 5px;
        border-style: solid;
        border-color: #999999 transparent transparent;
        visibility: hidden;
        opacity: 0;
        transition: opacity 0.3s;
    }
    
    .tooltip:hover:before,
    .tooltip:hover:after{
        visibility: visible;
        opacity: 1;
    }
    

    【讨论】:

    • 也可以随意将代码放在代码标签中,以防万一链接发生问题,并使其在本网站上更容易获得。
    猜你喜欢
    • 2013-12-11
    • 1970-01-01
    • 1970-01-01
    • 2017-10-25
    • 1970-01-01
    • 2015-06-28
    • 2015-09-13
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多