vue3超出文本展示el tooltip實(shí)現(xiàn)示例
實(shí)現(xiàn)思路
最近在做項(xiàng)目的時(shí)候遇到一個(gè)樣式,文本超出某個(gè)寬度的時(shí)候需要展示...,鼠標(biāo)移上去展示提示信息,如果過(guò)沒(méi)有超出寬度則不展示提示框。這篇文章主要就是介紹如何實(shí)現(xiàn)的。
首先我們分析一下要根據(jù)文本的寬度是否超過(guò)展示提示框,那么就必須要獲取文本的寬度和容器的寬度,然后還要根據(jù)el-tooltip的disabled屬性來(lái)判斷是否需要展示tool-tip。我們可以通過(guò)自定義一個(gè)指令來(lái)是實(shí)現(xiàn)。大致思路如下:
- 獲取容器的寬度,獲取文本的寬度。
- 判斷寬度,并且監(jiān)聽(tīng)mouseenter事件,如果文本的寬度>容器的寬度, 就將tool-tip的disabled的屬性設(shè)置為false,否則就設(shè)置為true
特別注意:
- 在vue3中,我們不能將指定綁定在el-tooltip上,而是需要綁定在el-tooltip的外層容器上。因此在獲取元素的時(shí)候就需要在外層容器上內(nèi)查找el-tooltop。
- 在計(jì)算元素的寬度的時(shí)候還要考慮左右的padding的大小
代碼實(shí)現(xiàn)
1. 創(chuàng)建一個(gè)自定義指令文件showTip.js。
該文件放在directives文件夾下。內(nèi)容如下:
import { getStyle } from 'element-plus/lib/utils/dom/index';
const showTip = {
created(el, binding, vnode) {
let tooltipNode = vnode.children.find((childCmpt) => childCmpt.component?.type.name == 'ElTooltip');
if (tooltipNode) {
// let { content } = tooltipNode.props;
el.addEventListener('mouseenter', () => {
tooltipNode.component.props.disabled = true;
const range = document.createRange();
range.setStart(el, 0);
range.setEnd(el, el.childNodes.length);
const rangeWidth = Math.round(range.getBoundingClientRect().width);
const padding = (parseInt(getStyle(el, 'paddingLeft'), 10) || 0) + (parseInt(getStyle(el, 'paddingRight'), 10) || 0);
if (rangeWidth + padding > el.offsetWidth || el.scrollWidth > el.offsetWidth) {
tooltipNode.component.props.disabled = false;
}
});
}
}
};
export default showTip;
2. 全局引入
在main.js中引入該指令文件
import { createApp } from 'vue'
import App from './App.vue'
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import showTip from './directives/showTip.js';
const app = createApp(App);
app.directive('show-tip', showTip);
app.use(ElementPlus).mount('#app');
3. 組件中使用
在需要使用的組件中使用該指令
<template>
<div class="test-wrapper">
<div class="test-value" v-show-tip>
<el-tooltip placement="top" :content="name">{{name}}</el-tooltip>
</div>
</div>
</template>
<script setup>
const name = '這是一段一段一段一段一段非常非常非常非常長(zhǎng)長(zhǎng)的文本';
</script>
<style scoped>
.test-value {
width: 20%;
display: inline-block;
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
}
</style>
效果如下: 文本超出,鼠標(biāo)移上去就會(huì)展示提示信息。
總結(jié)
文本超出展示詳細(xì)信息在實(shí)際開(kāi)發(fā)中是經(jīng)常會(huì)用到的,自定義一個(gè)指令,這樣需要的時(shí)候就可以直接引用了。
以上就是vue3超出文本展示el tooltip實(shí)現(xiàn)示例的詳細(xì)內(nèi)容,更多關(guān)于vue 超出文本展示el tooltip的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue3使用vue-office插件實(shí)現(xiàn)word預(yù)覽功能
vue-office是一個(gè)支持多種文件(docx、.xlsx、pdf)預(yù)覽的vue組件庫(kù),支持vue2和vue3,這篇文章主要介紹了Vue3使用vue-office插件實(shí)現(xiàn)word預(yù)覽功能,需要的朋友可以參考下2024-04-04
關(guān)于vue.extend的使用及說(shuō)明
這篇文章主要介紹了關(guān)于vue.extend的使用及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
element?el-upload文件上傳覆蓋第一個(gè)文件的實(shí)現(xiàn)
這篇文章主要介紹了element?el-upload文件上傳覆蓋第一個(gè)文件的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
vue+Element中table表格實(shí)現(xiàn)可編輯(select下拉框)
這篇文章主要介紹了vue+Element中table表格實(shí)現(xiàn)可編輯,實(shí)現(xiàn)select下拉框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05
Vue數(shù)據(jù)雙向綁定底層實(shí)現(xiàn)原理
這篇文章主要為大家詳細(xì)介紹了Vue數(shù)據(jù)雙向綁定底層實(shí)現(xiàn)原理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11
vue導(dǎo)出excel多層表頭的實(shí)現(xiàn)方案詳解
這篇文章主要為大家詳細(xì)介紹了vue導(dǎo)出excel多層表頭的實(shí)現(xiàn)方案,文中的示例代碼簡(jiǎn)潔易懂,具有一定的借鑒價(jià)值,有需要的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-04-04

