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>
相关推荐
WeiXiao_Hyy24 分钟前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
吃杠碰小鸡41 分钟前
高中数学-数列-导数证明
前端·数学·算法
kingwebo'sZone1 小时前
C#使用Aspose.Words把 word转成图片
前端·c#·word
xjt_09011 小时前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
我是伪码农1 小时前
Vue 2.3
前端·javascript·vue.js
夜郎king2 小时前
HTML5 SVG 实现日出日落动画与实时天气可视化
前端·html5·svg 日出日落
辰风沐阳2 小时前
JavaScript 的宏任务和微任务
javascript
跳动的梦想家h2 小时前
环境配置 + AI 提效双管齐下
java·vue.js·spring
夏幻灵3 小时前
HTML5里最常用的十大标签
前端·html·html5
冰暮流星3 小时前
javascript之二重循环练习
开发语言·javascript·数据库