vue+elemen實(shí)現(xiàn)el-tooltip在文本超出區(qū)域后浮現(xiàn)
前言
最近在做一個(gè)vue+element的項(xiàng)目,遇到的一些難搞的需求。
關(guān)于<el-tooltip>的使用想必也不用我多說(shuō)了,官方文檔是相當(dāng)?shù)脑敿?xì),基本使用自己去餓了么官網(wǎng)看。
具體需求
由于我的內(nèi)容是循環(huán)生成的,字體的多少,并不是一個(gè)定值,如果僅使用官方的<el-tooltip>組件的話,豈不是包著的每一個(gè)div都會(huì)有這個(gè)tooltip,結(jié)果導(dǎo)致一整個(gè)頁(yè)面的tooltip,體驗(yàn)特別不好。而且整個(gè)頁(yè)面生成了上百個(gè)<el-tooltip>標(biāo)簽,占用了大量的資源。
解決方案
方案一
剛開(kāi)始在網(wǎng)上翻找解決方案,找到一個(gè)別人將tooltip組件二次封裝,好用確實(shí)是好用,但是同樣會(huì)生成大量的tooltip標(biāo)簽,遂放棄。
方案二
后來(lái),我想到了一個(gè)我用過(guò)的表格屬性——:show-overflow-tooltip=“true”——在表格組件中,某一個(gè)單元格中的內(nèi)容超過(guò)了該單列的列寬,會(huì)隱藏多余部分,通過(guò)…展示。并且將鼠標(biāo)移入即可查看該單元格內(nèi)的完整內(nèi)容。效果如圖:

而鼠標(biāo)放到文字沒(méi)超出列寬的地方則不顯示 tooltip,神奇的是,整個(gè)頁(yè)面,只生成了一個(gè)<el-tooltip>標(biāo)簽,無(wú)論有多少內(nèi)容,永遠(yuǎn)只有一個(gè)<el-tooltip>存在,大大節(jié)省了資源。于是翻看源碼看他是怎么實(shí)現(xiàn)該功能的。

具體方法
1.先在頁(yè)面上定義一個(gè)tooltip標(biāo)簽
<el-tooltip ref="tooltip" :content="tooltipContent" />
此標(biāo)簽就是要在頁(yè)面中生成的那個(gè)唯一的<el-tooltip>標(biāo)簽。
2.在文字區(qū)域的父標(biāo)簽上添加鼠標(biāo)移入移除方法
<div
class="card-carousel--card--footer"
@mouseenter="handleDivMouseEnter($event)"
@mouseleave="handleDivMouseleave($event)"
>
<p class="topicStyle"> {{ info } </p>
</div>
前提是:承載內(nèi)容的標(biāo)簽需要有一個(gè)class。若要在組件標(biāo)簽上添加方法,應(yīng)該是要添加【.native】的。
3.引入需要的方法
import debounce from 'throttle-debounce/debounce'
import { getStyle } from '@/utils/dom.js
在created中添加
created() {
this.activateTooltip = debounce(50, tooltip => tooltip.handleShowPopper())
},
此處getStyle方法是自動(dòng)計(jì)算邊距,我將源碼中的js提出來(lái),方便使用。
源碼位置:\element-dev\packages\table\src\table-body.js
4.在methods添加鼠標(biāo)移入移出方法
// 鼠標(biāo)移入
handleDivMouseEnter(event) {
const target = event.target
// 判斷是否text-overflow, 如果是就顯示tooltip
let child = target.querySelector('.groupItemClass')
// 在此處我一共有三個(gè)class控制三塊class,這一塊主要是對(duì)<el-menu>以及文本區(qū)域控制,所以class要有多個(gè)。
// 如果區(qū)域?qū)挾缺幌薅?,則通過(guò)高度判斷
let heightFlag = false
if (!child) {
child = target.querySelector('.setItemClass')
if (!child) {
// 文本區(qū)域
child = target.querySelector('.topicStyle')
}
}
if (child.scrollHeight > child.offsetHeight) {
heightFlag = true
}
// use range width instead of scrollWidth to determine whether the text is overflowing
// to address a potential FireFox bug: https://bugzilla.mozilla.org/show_bug.cgi?id=1074543#c3
const range = document.createRange()
range.setStart(child, 0)
range.setEnd(child, child.childNodes.length)
const rangeWidth = range.getBoundingClientRect().width // 文本區(qū)域?qū)挾?
const padding = (parseInt(getStyle(target, 'paddingLeft'), 10) || 0) +
(parseInt(getStyle(target, 'paddingRight'), 10) || 0)
if ((rangeWidth + padding > target.offsetWidth || child.scrollWidth > child.offsetWidth) || heightFlag && this.$refs.tooltip) {
const tooltip = this.$refs.tooltip
// TODO 會(huì)引起整個(gè) Table 的重新渲染,需要優(yōu)化
this.tooltipContent = target.innerText || target.textContent
tooltip.referenceElm = target
tooltip.$refs.popper && (tooltip.$refs.popper.style.display = 'none')
tooltip.doDestroy()
tooltip.setExpectedState(true)
this.activateTooltip(tooltip)
}
}
// 鼠標(biāo)移出
handleDivMouseleave(event) {
const tooltip = this.$refs.tooltip
if (tooltip) {
tooltip.setExpectedState(false)
tooltip.handleClosePopper()
}
},
效果展示

而且在頁(yè)面中只生成一個(gè)<el-tooltip>標(biāo)簽。

根據(jù)不同的情況可以通過(guò)判斷寬度和高度,對(duì)自己的頁(yè)面進(jìn)行一定的兼容,對(duì)方法handleDivMouseEnter()進(jìn)行相應(yīng)的修改。
到此這篇關(guān)于vue+elemen實(shí)現(xiàn)el-tooltip在文本超出區(qū)域后浮現(xiàn)的文章就介紹到這了,更多相關(guān)elemen el-tooltip文本超出浮現(xiàn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
前端vue中實(shí)現(xiàn)文件下載的幾種方法總結(jié)
這篇文章主要介紹了前端vue中實(shí)現(xiàn)文件下載的幾種方法總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04
Vue項(xiàng)目查看當(dāng)前使用的elementUI版本的方法
今天小編就為大家分享一篇Vue項(xiàng)目查看當(dāng)前使用的elementUI版本的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09
Vue 多選框所選數(shù)量動(dòng)態(tài)變換Box的高度
在Web開(kāi)發(fā)中,使用Vue.js框架可以通過(guò)ref屬性、v-model指令和計(jì)算屬性等特性實(shí)現(xiàn)元素高度的動(dòng)態(tài)調(diào)整,文章詳細(xì)介紹了如何利用Vue的功能根據(jù)多選框的選擇數(shù)量動(dòng)態(tài)改變?cè)氐母叨?并通過(guò)多個(gè)示例展示其應(yīng)用2024-09-09
Vuex實(shí)現(xiàn)購(gòu)物車(chē)小功能
這篇文章主要為大家詳細(xì)介紹了Vuex實(shí)現(xiàn)購(gòu)物車(chē)小功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08
淺談vue使用axios的回調(diào)函數(shù)中this不指向vue實(shí)例,為undefined
element-ui 表格sortable排序手動(dòng)js清除方式
Vue中的函數(shù)同步執(zhí)行導(dǎo)致的數(shù)據(jù)獲取失敗問(wèn)題處理辦法

