vue自定义指令添加跟随鼠标光标提示框v-tooltip方式

 更新时间:2022年10月21日 09:16:51   作者:骑上我心爱的小摩托  
这篇文章主要介绍了vue自定义指令添加跟随鼠标光标提示框v-tooltip方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

自定义指令添加跟随鼠标光标提示框v-tooltip

在vue中添加自定义指令,能够识别dom,通过鼠标hover事件移入当前区域后,显示浮层

1、directives自定义提示指令

  directives: {
    // 自定义提示指令
    tooltip: {
      componentUpdated: function(el, binding) {
        // 鼠标移入时,将浮沉元素插入到body中
        el.onmouseenter = function(e) {
          // 创建浮层元素并设置样式
          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
        `;
          // 设置id方便寻找
          vcTooltipDom.setAttribute('id', 'vc-tooltip');
          // 将浮层插入到body中
          document.body.appendChild(vcTooltipDom);
          // 浮层中的文字 通过属性值传递动态的显示文案
          document.getElementById('vc-tooltip').innerHTML = el.getAttribute('tips');
        };
        // 鼠标移动时,动态修改浮沉的位置属性
        el.onmousemove = function(e) {
          const vcTooltipDom = document.getElementById('vc-tooltip');
          vcTooltipDom.style.top = e.clientY + 15 + 'px';
          vcTooltipDom.style.left = e.clientX + 15 + 'px';
        };
        // 鼠标移出时将浮层元素销毁
        el.onmouseleave = function() {
          // 找到浮层元素并移出
          const vcTooltipDom = document.getElementById('vc-tooltip');
          vcTooltipDom && document.body.removeChild(vcTooltipDom);
        };
      }
    }
  }

通过监听鼠标移入移出的mouse方法,设置浮层样式与出现时机

2、div显示dom标签v-tooltip

<div id="bar-echart" tips="共有6个任务执行成功" v-tooltip/>

此时运行后,出现浮层

vue自定义指令实现tooltip功能

1、需求

元素展示提示框跟随鼠标移动

2、思路

vue的自定义指令

将显示内容放到容器中,通过值传递,监听鼠标移入事件,鼠标移入后将容器append到body

  • 监听鼠标移动事件,根据鼠标的e.clientY,e.clientX修改容器位置
  • 监听鼠标移出事件,销毁容器

3、代码

// 自定义提示指令
directives: {
    tooltip(el, binding){
        // 鼠标移入时,将浮沉元素插入到body中
        el.onmouseenter = function (e) {
          // 创建浮层元素并设置样式
          const vcTooltipDom = document.createElement("div");
          vcTooltipDom.style.cssText = `
                  position:absolute;
                  background: #fff;;
                  color:#fff;
                  font-size:14px;
                  z-index:1000
            ;
          // 设置id方便寻找
          vcTooltipDom.setAttribute("id", "vc-tooltip");
          // 将浮层插入到body中
          document.body.appendChild(vcTooltipDom);
          // 浮层中的文字 通过属性值传递动态的显示文案
          document.getElementById("vc-tooltip").innerHTML =
            el.getAttribute("tips");
        };
        // 鼠标移动时,动态修改浮沉的位置属性
        el.onmousemove = function (e) {
          const vcTooltipDom = document.getElementById("vc-tooltip");
          vcTooltipDom.style.top = e.clientY + 15 + "px";
          vcTooltipDom.style.left = e.clientX + 15 + "px";
        };
        // 鼠标移出时将浮层元素销毁
        el.onmouseleave = function () {
          // 找到浮层元素并移出
          const vcTooltipDom = document.getElementById("vc-tooltip");
          vcTooltipDom && document.body.removeChild(vcTooltipDom);
        };
    },
  },

4、在元素上使用

<div v-tooltip :tip='youtxt'></div>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue多页面配置详情

    vue多页面配置详情

    这篇文章主要介绍了vue多页面配置,单页应用这个概念,是随着前几年 AngularJS、React、Ember 等这些框架的出现而出现的。在前面的前言内容里,我们在页面渲染中讲了页面的局部刷新,而单页应用则是使用了页面的局部刷新的能力,下面来看看详细内容,需要的朋友可以参考一下
    2021-11-11
  • 关于Vue Webpack2单元测试示例详解

    关于Vue Webpack2单元测试示例详解

    这篇文章主要给大家介绍了关于Vue Webpack2单元测试的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面跟着小编来一起学习学习吧。
    2017-08-08
  • 讲解vue-router之什么是编程式路由

    讲解vue-router之什么是编程式路由

    编程式路由在我们的项目使用过程中最常用的的方法了。这篇文章主要介绍了讲解vue-router之什么是编程式路由,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • Vue实现电梯样式锚点导航效果流程详解

    Vue实现电梯样式锚点导航效果流程详解

    这篇文章主要介绍了Vue实现电梯样式锚点导航效果流程,这种导航效果广泛应用于商城点餐购物情景,文中通过示例代码介绍的很详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2023-05-05
  • vue开发之LogicFlow自定义业务节点

    vue开发之LogicFlow自定义业务节点

    这篇文章主要为大家介绍了vue开发之LogicFlow自定义业务节点,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • ElementPlus 自定义封装 el-date-picker 的快捷功能示例详解

    ElementPlus 自定义封装 el-date-picker 的快捷功能示例详解

    文章讨论了用户对官网提供的案例不满足快捷功能需求的情况,建议在外部自定义组件中导入并使用快捷内容,以满足用户需求,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧
    2024-12-12
  • vue使用less报错:Inline JavaScript is not enabled问题

    vue使用less报错:Inline JavaScript is not ena

    这篇文章主要介绍了vue使用less报错:Inline JavaScript is not enabled问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • Vue组件中的data必须是一个function的原因浅析

    Vue组件中的data必须是一个function的原因浅析

    这篇文章主要介绍了Vue组件中的data必须是一个function的原因浅析,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-09-09
  • vue2与vue3中生命周期执行顺序的区别说明

    vue2与vue3中生命周期执行顺序的区别说明

    这篇文章主要介绍了vue2与vue3中生命周期执行顺序的区别说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • 关于Element-ui中table默认选中toggleRowSelection问题

    关于Element-ui中table默认选中toggleRowSelection问题

    这篇文章主要介绍了关于Element-ui中table默认选中toggleRowSelection问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08

最新评论