自定义VUE指定,实现鼠标悬停显示提示面板,离开元素或面板后面板消失

参考文档:https://www.bilibili.com/opus/500023412612186477

javascript 复制代码
// 自定义"v-tooltip"指令,实现鼠标悬浮显示文本
Vue.directive('tooltip', {
    bind(element, binding) {
        const tooltipText = binding.value;
        const tooltip = document.createElement('div');
        tooltip.innerHTML = tooltipText;
        tooltip.style.position = 'absolute';
        tooltip.style.display = 'none';
        tooltip.style.background = '#ffffff';
        tooltip.style.borderRadius = '4px';
        tooltip.style.width = '95%';
        tooltip.style.margin = '0px 40px';
        tooltip.style.padding = '5px 10px';
        tooltip.style.fontSize = '12px';
        tooltip.style.textAlign = 'left';
        tooltip.style.zIndex = '1000';
        document.body.appendChild(tooltip);

        // 执行鼠标悬停在元素和面板上展示,离开后面板消失。
        setSecondaryMenu(element, tooltip, 1000);
    }
});

/**
 * 给两个元素绑定事件,鼠标悬停在元素和面板上展示,离开后面板消失。
 * 原理:
 * 鼠标放到按钮上,面板显示出来,鼠标移出按钮,面板延迟dt毫秒消失。
 * 鼠标移出后,面板消失之前,移动到面板上,取消面板的延迟消失
 * 鼠标移出面板后,同样延时dt毫秒消失
 * @param {*} element 鼠标悬停的元素
 * @param {*} tooltip 面板元素
 * @param {*} delayTime 延迟消失的时间,毫秒(ms)
 */
function setSecondaryMenu(element, tooltip, delayTime) {
    /** 鼠标移开按钮后面板延迟消失的时间(ms) */
    var delayTask;

    /**鼠标移入按钮 */
    element.addEventListener("mouseenter", (event) => {
        let rect = element.getBoundingClientRect();
        tooltip.style.display = 'block';
        tooltip.style.top = rect.bottom + 'px';
        clearTimeout(delayTask);
    });
    /**鼠标移出按钮 */
    element.addEventListener("mouseleave", (event) => {
        delayTask = setTimeout(() => {
            tooltip.style.display = 'none';
        }, delayTime);
    });
    /**鼠标移入面板 */
    tooltip.addEventListener("mouseenter", (event) => {
        clearTimeout(delayTask);
    });
    /**鼠标移出面板 */
    tooltip.addEventListener("mouseleave", (event) => {
        delayTask = setTimeout(() => {
            tooltip.style.display = 'none';
        }, delayTime);
    });
}
相关推荐
灵感__idea7 小时前
Hello 算法:贪心的世界
前端·javascript·算法
GreenTea8 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd10 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌10 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈10 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫11 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝11 小时前
svg图片
前端·css·学习·html·css3
橘子编程11 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
王夏奇11 小时前
python中的__all__ 具体用法
java·前端·python
叫我一声阿雷吧11 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint