纯CSS实现悬浮提示并封装成vue组件

简介: 🎈平时给文字加悬浮提示,我们通常都是直接使用title属性来实现,但是这样的效果并不好看,那我们可以自己动手做一个tooltip悬浮提示框吗?说做就做,让我们一起来看看✍️

说在前面

🎈平时给文字加悬浮提示,我们通常都是直接使用title属性来实现,但是这样的效果并不好看,那我们可以自己动手做一个tooltip悬浮提示框吗?说做就做,让我们一起来看看✍️

效果

JYeontu组件库 - Google Chrome 2022_4_5 15_27_03 00_00_00-00_00_30.gif

预览地址:http://jyeontu.xyz/jvuewheel/#/JToolTipView

效果实现

HTML部分

如下图,简单写一段话使用p标签包裹起来,span标签中的内容是需要我们设置悬浮提示的内容。

<p>
    I am
    <span class="j-tooltip">
        title
    </span>
    .
</p>

CSS部分

为文字加上下划虚线

这里使用border-bottom来实现:
border-bottom: 1px dotted black;

悬浮提示弹框

使用before来设置弹出提示内容,content为提示文字,初始设置opacity为0,并添加过渡效果

opacity: 0;
transition: opacity 0.6s;

通过visibility属性设置元素隐藏

visibility:hidden;

hover时显示提示框

.j-tooltip:hover:before {
    opacity: 1;
    visibility: visible;
}

完整css代码

.j-tooltip {
    position: relative;
    border-bottom: 1px dotted black;
}
.j-tooltip:before {
    content: "title";
    position: absolute;
    width: 100px;
    background-color: #062b45;
    color: white;
    text-align: center;
    padding: 10px;
    line-height: 1.2;
    border-radius: 6px;
    z-index: 1;
    opacity: 0;
    transition: opacity 0.6s;
    bottom: 125%;
    left: 50%;
    margin-left: -60px;
    font-size: 0.75em;
    visibility: hidden;
    word-break: break-all;
}

.j-tooltip:hover:before {
    opacity: 1;
    visibility: visible;
}

效果

将鼠标移动到title上面时会弹出这样一个提示。
1649144644(1).png

组件封装

既然我们知道了效果的实现方法,为了方便以后复用,我们肯定是要将其封装成组件才会更加方便,接下来就让我们一起将其封装成一个vue组件。

参数配置

为了使组件的可用性更高,我们需要使其参数可以进行配置。

  • tipText

tipText可以设置提示框中的文字

  • textStyle

设置需要悬浮提示的文字样式,如给文字加上下划线。

  • toolTipStyle

设置提示框样式,如:宽度,字体颜色,背景颜色等……

props: {
    tipText: {
        type: String,
        default: "Tooltip Content"
    },
    textStyle: {
        type: Object,
        default: () => {
            return {
                "border-bottom": "1px dotted black"
            };
        }
    },
    toolTipStyle: {
        type: Object,
        default: () => {
            return {
                backgroundColor: "#062b45",
                color: "#fff",
                width: "100px"
            };
        }
    }
},

HTML部分

使用:style定义css变量,后面可以在css中取到该值。

<span
    :style="{
        '--backgroundColor': toolTipStyle.backgroundColor,
        '--color': toolTipStyle.color,
        '--width': toolTipStyle.width
    }"
>
    <span
        :id="uid"
        class="j-tooltip"
        :data-tooltip="tipText"
        :style="getTextStyle()"
        ><slot></slot>
    </span>
</span>

CSS部分

  • 获取声明css变量

<style vars="{ backgroundColor, color, width }" lang="scss" scoped>

  • 使用css变量
width: var(--width);
background-color: var(--backgroundColor);
color: var(--color);
  • 完整代码
<style vars="{ backgroundColor, color, width }" lang="scss" scoped>
.j-tooltip {
    position: relative;
    border-bottom: 1px dotted black;
}

.j-tooltip:before {
    content: attr(data-tooltip);
    position: absolute;
    width: var(--width);
    background-color: var(--backgroundColor);
    color: var(--color);
    text-align: center;
    padding: 10px;
    line-height: 1.2;
    border-radius: 6px;
    z-index: 1;
    opacity: 0;
    transition: opacity 0.6s;
    bottom: 125%;
    left: 50%;
    margin-left: -60px;
    font-size: 0.75em;
    visibility: hidden;
    word-break: break-all;
}

.j-tooltip:hover:before{
    opacity: 1;
    visibility: visible;
}
</style>

组件调用

封装成组件之后我们可以很方便地进行调用,每次只需要设置对应的参数即可,无需重复编写css样式代码。

HTML

<p>
    hover
    <j-tool-tip
        tipText="one"
        :textStyle="textStyle"
        :toolTipStyle="toolTipStyle"
        >here
    </j-tool-tip>
    to see one.
</p>
<p>
    hover
    <j-tool-tip tipText="another">here </j-tool-tip>
    to see another.
</p>

JavaScript

textStyle: {
    borderBottom: "1px dotted skyblue",
    fontSize: "large",
    color: "skyblue"
},
toolTipStyle: {
    backgroundColor: "grey",
    color: "skyblue",
    width: "100px"
},

源码地址

组件库:http://jyeontu.xyz/jvuewheel

Gitee:https://gitee.com/zheng_yongtao/jyeontu-component-warehouse.git

个人博客:http://jyeontu.xyz/JYeontuBlog

说在后面

🎉这里是JYeontu,现在是一名前端工程师,有空会刷刷算法题,平时喜欢打羽毛球🏸 ,平时也喜欢写些东西,既为自己记录📋,也希望可以对大家有那么一丢丢的帮助,写的不好望多多谅解🙇,写错的地方望指出,定会认真改进😊,在此谢谢大家的支持,我们下文再见🙌。
目录
相关文章
|
2月前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
154 64
|
2月前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
45 8
|
2月前
|
JavaScript
在 Vue 3 中,如何使用 v-model 来处理自定义组件的双向数据绑定?
需要注意的是,在实际开发中,根据具体的业务需求和组件设计,可能需要对上述步骤进行适当的调整和优化,以确保双向数据绑定的正确性和稳定性。同时,深入理解 Vue 3 的响应式机制和组件通信原理,将有助于更好地运用 `v-model` 实现自定义组件的双向数据绑定。
|
2月前
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。
|
2月前
|
存储 JavaScript
Vue 组件间如何通信
Vue组件间通信是指在Vue应用中,不同组件之间传递数据和事件的方法。常用的方式有:props、自定义事件、$emit、$attrs、$refs、provide/inject、Vuex等。掌握这些方法可以实现父子组件、兄弟组件及跨级组件间的高效通信。
|
2月前
|
缓存 JavaScript UED
Vue 中实现组件的懒加载
【10月更文挑战第23天】组件的懒加载是 Vue 应用中提高性能的重要手段之一。通过合理运用动态导入、路由配置等方式,可以实现组件的按需加载,减少资源浪费,提高应用的响应速度和用户体验。在实际应用中,需要根据具体情况选择合适的懒加载方式,并结合性能优化的其他措施,以打造更高效、更优质的 Vue 应用。
|
3月前
|
前端开发 UED
vue3知识点:Suspense组件
vue3知识点:Suspense组件
47 4
|
3月前
|
JavaScript 前端开发 测试技术
组件化开发:创建可重用的Vue组件
【10月更文挑战第21天】组件化开发:创建可重用的Vue组件
34 1
|
3月前
|
JavaScript 前端开发 Java
《vue3第五章》新的组件,包含:Fragment、Teleport、Suspense
《vue3第五章》新的组件,包含:Fragment、Teleport、Suspense
48 2
|
3月前
|
Java
vue3知识点:Teleport组件
vue3知识点:Teleport组件
37 1
下一篇
开通oss服务