Vue封装Tooltip(提示工具)

javascript 复制代码
<template>  
  <div class="tooltip" @mouseover="showTooltip" @mouseleave="hideTooltip">  
    <slot></slot> <!-- 使用slot来接收传入的内容 -->  
    <span class="tooltiptext" v-if="visible">{{ tooltipText }}</span>  
  </div>  
</template>

<script>  
export default {  
  name: 'Tooltip',  
  props: {  
    tooltipText: String // 接收外部传入的提示文本  
  },  
  data() {  
    return {  
      visible: false // 控制提示框的显示隐藏  
    };  
  },  
  methods: {  
    showTooltip() {  
      this.visible = true;  
    },  
    hideTooltip() {  
      this.visible = false;  
    }  
  }  
}  
</script>

<style scoped>  
.tooltip {  
  position: relative;  
  display: inline-block; /* 确保Tooltip可以跟随内容的宽度 */  
  /* 可以添加一些内边距或外边距来避免内容过于紧凑 */  
  padding: 5px;  
  margin: 10px;  
  border-bottom: none; /* 移除底部边框,因为它可能不再需要 */  
  /* 其他样式可以根据需要添加 */  
}  
  
.tooltip .tooltiptext {  
  visibility: hidden;  
  width: auto; /* 使用auto宽度可以适应内容 */  
  background-color: black;  
  color: #fff;  
  text-align: center;  
  border-radius: 6px;  
  padding: 5px 10px; /* 增加水平内边距以改善可读性 */  
    
  /* 定位 */  
  position: absolute;  
  z-index: 1;  
  bottom: 100%; /* 原始位置,但我们会用transform来调整 */  
  left: 50%;  
  transform: translateX(-50%) translateY(-10px); /* 将Tooltip向上移动 */  
  /* 可以添加箭头样式 */  
  ::after {  
    content: " ";  
    position: absolute;  
    bottom: 100%; /* Tooltip底部 */  
    left: 50%;  
    margin-left: -5px;  
    border-width: 5px;  
    border-style: solid;  
    border-color: black transparent transparent transparent;  
  }  
}  
  
/* 当Tooltip可见时 */  
.tooltip:hover .tooltiptext {  
  visibility: visible;  
}  
</style>

使用

javascript 复制代码
<template>  
  <div>  
    <Tooltip tooltipText="这是提示文本">  
      鼠标悬停在这里  
    </Tooltip>  
  </div>  
</template>  

<script>  
import Tooltip from './components/Tooltip.vue';  

export default {  
  components: {  
    Tooltip  
  }  
}  
</script>
相关推荐
大怪v36 分钟前
【Virtual World 04】我们的目标,无限宇宙!!
前端·javascript·代码规范
狂炫冰美式1 小时前
不谈技术,搞点文化 🧀 —— 从复活一句明代残诗破局产品迭代
前端·人工智能·后端
xw52 小时前
npm几个实用命令
前端·npm
!win !2 小时前
npm几个实用命令
前端·npm
代码狂想家2 小时前
使用openEuler从零构建用户管理系统Web应用平台
前端
dorisrv3 小时前
优雅的React表单状态管理
前端
蓝瑟4 小时前
告别重复造轮子!业务组件多场景复用实战指南
前端·javascript·设计模式
老华带你飞4 小时前
旅游|基于Java旅游信息系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·旅游
dorisrv4 小时前
高性能的懒加载与无限滚动实现
前端
韭菜炒大葱4 小时前
别等了!用 Vue 3 让 AI 边想边说,字字蹦到你脸上
前端·vue.js·aigc