vue自定義指令添加跟隨鼠標(biāo)光標(biāo)提示框v-tooltip方式
自定義指令添加跟隨鼠標(biāo)光標(biāo)提示框v-tooltip
在vue中添加自定義指令,能夠識(shí)別dom,通過鼠標(biāo)hover事件移入當(dāng)前區(qū)域后,顯示浮層
1、directives自定義提示指令
? directives: {
? ? // 自定義提示指令
? ? tooltip: {
? ? ? componentUpdated: function(el, binding) {
? ? ? ? // 鼠標(biāo)移入時(shí),將浮沉元素插入到body中
? ? ? ? el.onmouseenter = function(e) {
? ? ? ? ? // 創(chuàng)建浮層元素并設(shè)置樣式
? ? ? ? ? const vcTooltipDom = document.createElement('div');
? ? ? ? ? vcTooltipDom.style.cssText = `
? ? ? ? ? overflow: auto;
? ? ? ? ? position:absolute;
? ? ? ? ? background: #fff;;
? ? ? ? ? color:#666;
? ? ? ? ? box-shadow: rgba(168, 168, 168, 0.295) 1px 2px 10px;
? ? ? ? ? border-radius:5px;
? ? ? ? ? padding:10px;
? ? ? ? ? display:inline-block;
? ? ? ? ? font-size:14px;
? ? ? ? ? z-index:2
? ? ? ? `;
? ? ? ? ? // 設(shè)置id方便尋找
? ? ? ? ? vcTooltipDom.setAttribute('id', 'vc-tooltip');
? ? ? ? ? // 將浮層插入到body中
? ? ? ? ? document.body.appendChild(vcTooltipDom);
? ? ? ? ? // 浮層中的文字 通過屬性值傳遞動(dòng)態(tài)的顯示文案
? ? ? ? ? document.getElementById('vc-tooltip').innerHTML = el.getAttribute('tips');
? ? ? ? };
? ? ? ? // 鼠標(biāo)移動(dòng)時(shí),動(dòng)態(tài)修改浮沉的位置屬性
? ? ? ? el.onmousemove = function(e) {
? ? ? ? ? const vcTooltipDom = document.getElementById('vc-tooltip');
? ? ? ? ? vcTooltipDom.style.top = e.clientY + 15 + 'px';
? ? ? ? ? vcTooltipDom.style.left = e.clientX + 15 + 'px';
? ? ? ? };
? ? ? ? // 鼠標(biāo)移出時(shí)將浮層元素銷毀
? ? ? ? el.onmouseleave = function() {
? ? ? ? ? // 找到浮層元素并移出
? ? ? ? ? const vcTooltipDom = document.getElementById('vc-tooltip');
? ? ? ? ? vcTooltipDom && document.body.removeChild(vcTooltipDom);
? ? ? ? };
? ? ? }
? ? }
? }通過監(jiān)聽鼠標(biāo)移入移出的mouse方法,設(shè)置浮層樣式與出現(xiàn)時(shí)機(jī)
2、div顯示dom標(biāo)簽v-tooltip
<div id="bar-echart" tips="共有6個(gè)任務(wù)執(zhí)行成功" v-tooltip/>
此時(shí)運(yùn)行后,出現(xiàn)浮層
vue自定義指令實(shí)現(xiàn)tooltip功能
1、需求
元素展示提示框跟隨鼠標(biāo)移動(dòng)
2、思路
vue的自定義指令
將顯示內(nèi)容放到容器中,通過值傳遞,監(jiān)聽鼠標(biāo)移入事件,鼠標(biāo)移入后將容器append到body
- 監(jiān)聽鼠標(biāo)移動(dòng)事件,根據(jù)鼠標(biāo)的e.clientY,e.clientX修改容器位置
- 監(jiān)聽鼠標(biāo)移出事件,銷毀容器
3、代碼
// 自定義提示指令
directives: {
? ? tooltip(el, binding){
? ? ? ? // 鼠標(biāo)移入時(shí),將浮沉元素插入到body中
? ? ? ? el.onmouseenter = function (e) {
? ? ? ? ? // 創(chuàng)建浮層元素并設(shè)置樣式
? ? ? ? ? const vcTooltipDom = document.createElement("div");
? ? ? ? ? vcTooltipDom.style.cssText = `
?? ??? ? ? ? ? ? ?position:absolute;
?? ??? ? ? ? ? ? ?background: #fff;;
?? ??? ? ? ? ? ? ?color:#fff;
?? ??? ? ? ? ? ? ?font-size:14px;
?? ??? ? ? ? ? ? ?z-index:1000
?? ??? ??? ?;
? ? ? ? ? // 設(shè)置id方便尋找
? ? ? ? ? vcTooltipDom.setAttribute("id", "vc-tooltip");
? ? ? ? ? // 將浮層插入到body中
? ? ? ? ? document.body.appendChild(vcTooltipDom);
? ? ? ? ? // 浮層中的文字 通過屬性值傳遞動(dòng)態(tài)的顯示文案
? ? ? ? ? document.getElementById("vc-tooltip").innerHTML =
? ? ? ? ? ? el.getAttribute("tips");
? ? ? ? };
? ? ? ? // 鼠標(biāo)移動(dòng)時(shí),動(dòng)態(tài)修改浮沉的位置屬性
? ? ? ? el.onmousemove = function (e) {
? ? ? ? ? const vcTooltipDom = document.getElementById("vc-tooltip");
? ? ? ? ? vcTooltipDom.style.top = e.clientY + 15 + "px";
? ? ? ? ? vcTooltipDom.style.left = e.clientX + 15 + "px";
? ? ? ? };
? ? ? ? // 鼠標(biāo)移出時(shí)將浮層元素銷毀
? ? ? ? el.onmouseleave = function () {
? ? ? ? ? // 找到浮層元素并移出
? ? ? ? ? const vcTooltipDom = document.getElementById("vc-tooltip");
? ? ? ? ? vcTooltipDom && document.body.removeChild(vcTooltipDom);
? ? ? ? };
? ? },
? },4、在元素上使用
<div v-tooltip :tip='youtxt'></div>
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于Vue Webpack2單元測(cè)試示例詳解
這篇文章主要給大家介紹了關(guān)于Vue Webpack2單元測(cè)試的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-08-08
Vue實(shí)現(xiàn)電梯樣式錨點(diǎn)導(dǎo)航效果流程詳解
這篇文章主要介紹了Vue實(shí)現(xiàn)電梯樣式錨點(diǎn)導(dǎo)航效果流程,這種導(dǎo)航效果廣泛應(yīng)用于商城點(diǎn)餐購物情景,文中通過示例代碼介紹的很詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-05-05
vue開發(fā)之LogicFlow自定義業(yè)務(wù)節(jié)點(diǎn)
這篇文章主要為大家介紹了vue開發(fā)之LogicFlow自定義業(yè)務(wù)節(jié)點(diǎn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01
ElementPlus 自定義封裝 el-date-picker 的快捷功能示例詳解
文章討論了用戶對(duì)官網(wǎng)提供的案例不滿足快捷功能需求的情況,建議在外部自定義組件中導(dǎo)入并使用快捷內(nèi)容,以滿足用戶需求,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧2024-12-12
vue使用less報(bào)錯(cuò):Inline JavaScript is not ena
這篇文章主要介紹了vue使用less報(bào)錯(cuò):Inline JavaScript is not enabled問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
Vue組件中的data必須是一個(gè)function的原因淺析
這篇文章主要介紹了Vue組件中的data必須是一個(gè)function的原因淺析,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09
vue2與vue3中生命周期執(zhí)行順序的區(qū)別說明
這篇文章主要介紹了vue2與vue3中生命周期執(zhí)行順序的區(qū)別說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
關(guān)于Element-ui中table默認(rèn)選中toggleRowSelection問題
這篇文章主要介紹了關(guān)于Element-ui中table默認(rèn)選中toggleRowSelection問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08

