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>
相关推荐
工业甲酰苯胺5 小时前
TypeScript枚举类型应用:前后端状态码映射的最简方案
javascript·typescript·状态模式
brzhang5 小时前
我操,终于有人把 AI 大佬们 PUA 程序员的套路给讲明白了!
前端·后端·架构
止观止6 小时前
React虚拟DOM的进化之路
前端·react.js·前端框架·reactjs·react
goms6 小时前
前端项目集成lint-staged
前端·vue·lint-staged
谢尔登6 小时前
【React Natve】NetworkError 和 TouchableOpacity 组件
前端·react.js·前端框架
Lin Hsüeh-ch'in6 小时前
如何彻底禁用 Chrome 自动更新
前端·chrome
augenstern4168 小时前
HTML面试题
前端·html
张可8 小时前
一个KMP/CMP项目的组织结构和集成方式
android·前端·kotlin
G等你下课9 小时前
React 路由懒加载入门:提升首屏性能的第一步
前端·react.js·前端框架
谢尔登9 小时前
【React Native】ScrollView 和 FlatList 组件
javascript·react native·react.js