使用 CSS 伪类的attr() 展示 tooltip

效果图:
请添加图片描述

使用场景: 使用React渲染后台返回的数据, 遍历以列表的形式展示, 可能简要字段内容需要鼠标放上去才显示的
可以借助DOM的自定义属性和CSS伪类的attr来实现

所有代码:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      li {
        list-style: none;
        position: relative;
      }

      li::before {
        /* attr函数, 参数就是li标签身上的属性 */
        content: attr(tip);
        position: absolute;
        right: 0;
        opacity: 0;
        color: burlywood;
        transition: opacity 500ms;
      }

      li:hover::before {
        opacity: 1;
      }
    </style>
  </head>
  <body>
    <div class="list">
      <li tip="list-item-1-tip">list-item-1</li>
      <li tip="list-item-2-tip">list-item-2</li>
      <li tip="list-item-3-tip">list-item-3</li>
    </div>
  </body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Tooltip(工具提示)是一种常见的UI元素,通常用于显示提示文本或信息,以帮助用户更好地理解或使用应用程序。在Web开发中,Tooltip通常使用CSS和JavaScript实现。 在HTML中,通常使用title属性来添加Tooltip文本。例如: ``` <button title="Click me">Button</button> ``` 这将为按钮添加一个简单的Tooltip,当用户将鼠标悬停在按钮上时,浏览器将显示一个包含“Click me”文本的小框。但是,这种方法的样式和行为都是由浏览器控制的,通常不能自定义。 要创建自定义样式和行为的Tooltip,可以使用CSS和JavaScript。例如,以下CSS样式定义了一个简单的Tooltip样式: ``` .tooltip { position: relative; } .tooltip:hover::before { content: attr(data-tooltip); position: absolute; top: -20px; left: 50%; transform: translateX(-50%); padding: 5px; background-color: #333; color: #fff; border-radius: 5px; font-size: 12px; opacity: 0.8; pointer-events: none; } ``` 这个CSS样式将在元素上创建一个Tooltip,当用户将鼠标悬停在元素上时显示。要使用这个样式,需要在HTML中添加一个具有data-tooltip属性的元素,例如: ``` <span class="tooltip" data-tooltip="This is a tooltip">Hover me</span> ``` 这将为“Hover me”文本创建一个Tooltip,当用户将鼠标悬停在该文本上时,将显示一个包含“This is a tooltip”文本的小框。 除了这种基本的Tooltip样式之外,还可以使用JavaScript添加更复杂的行为,例如延迟显示、动画效果等。关于如何使用JavaScript实现Tooltip,可以参考一些流行的UI库,例如Bootstrap、jQuery UI等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值