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>
相关推荐
筱歌儿几秒前
TinyMCE-----word表格图片进阶版
开发语言·javascript·word
Ama_tor38 分钟前
obsidian进阶の插件系列|Templater从小白到菜鸟
javascript·markdown·插件·obsidian
WordPress学习笔记44 分钟前
解决Bootstrap下拉菜单一级链接无法点击的问题
前端·bootstrap·html
Never_Satisfied1 小时前
C#插值字符串中大括号表示方法
前端·c#
wuhen_n1 小时前
初识TypeScript
javascript·typescript
w***76551 小时前
JS vs jQuery:核心差异解析
开发语言·javascript·jquery
踢球的打工仔1 小时前
typescript-类
前端·javascript·typescript
天天打码2 小时前
Svelte-无虚拟DOM、极致性能的现代高性能Web开发框架!
前端·node.js·vue·svelte
0思必得02 小时前
[Web自动化] Selenium元素定位
前端·python·selenium·自动化·html
EEEzhenliang2 小时前
CSS知识概括、总结
前端·css