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>

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

相关文章

  • Vue3源码通过render patch 了解diff

    Vue3源码通过render patch 了解diff

    这篇文章主要为大家介绍了Vue3源码系列通过render及patch了解diff原理详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • vue移动端实现手机左右滑动入场动画

    vue移动端实现手机左右滑动入场动画

    这篇文章主要为大家详细介绍了vue移动端实现手机左右滑动入场动画,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • vue使用threeJs导入obj模型并实现添加标注

    vue使用threeJs导入obj模型并实现添加标注

    这篇文章主要介绍了vue使用threeJs导入obj模型并实现添加标注方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • Vue打包路径配置过程

    Vue打包路径配置过程

    这篇文章主要介绍了Vue打包路径配置过程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • Vue.js中this如何取到data和method里的属性详解

    Vue.js中this如何取到data和method里的属性详解

    methods属性是一个对象,通常我们会在这个对象中定义很多的方法,下面这篇文章主要给大家介绍了关于Vue.js中this如何取到data和method里的属性,需要的朋友可以参考下
    2022-12-12
  • VUE实现强制渲染,强制更新

    VUE实现强制渲染,强制更新

    今天小编就为大家分享一篇VUE实现强制渲染,强制更新,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • vue中的vue-router query方式和params方式详解

    vue中的vue-router query方式和params方式详解

    这篇文章主要介绍了vue中的vue-router query方式和params方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • Vue项目部署之从本地到线上环境实践

    Vue项目部署之从本地到线上环境实践

    文章详细介绍了如何将Vue项目从本地环境部署到线上服务器,包括打包本地项目、服务器环境搭建、项目上传与配置以及解决部署后页面访问异常问题
    2026-02-02
  • 浅谈Vue3 Composition API如何替换Vue Mixins

    浅谈Vue3 Composition API如何替换Vue Mixins

    这篇文章主要介绍了浅谈Vue3 Composition API如何替换Vue Mixins,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • vue单页面在微信下只能分享落地页的解决方案

    vue单页面在微信下只能分享落地页的解决方案

    这篇文章主要介绍了vue单页面在微信下只能分享落地页的解决方案,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-04-04

最新评论