title属性样式不可调整 ,element-toolTip组件在有些情况下无法使用(比如swiper 无限滚动时)

写一个全局监听方法

js 复制代码
const parentDom = document.body
mounted() {
    document.body.addEventListener('mouseover', this.handleOver)
    // document.body.addEventListener('mouseleave', this.removeDom)
  },
  methods: {
    handleOver(e){
      var target = e.target;
      target.removeEventListener('mouseleave', this.removeDom)
      if (target.getAttribute('tooltip')) {
        // const parentDom = document.body
        // const parentDom = document.querySelector('#dv-full-screen-container')
        let tooltipText = target.getAttribute('tooltip'); //  获取当前所需文本
        // console.log(target)
        // 在此处编写点击事件处理逻辑
        const curStyle = window.getComputedStyle(target, '');
        // 获取当前hover元素的宽高和位置 用来确定 弹窗的位置
        let targetObj = target.getBoundingClientRect()
        console.log(targetObj)
        console.log(targetObj.top);
        // console.log(curStyle.width)
        // console.log(curStyle.height)

        const tooltip = document.createElement('div');
        tooltip.className = 'tooltipCls';
        tooltip.innerHTML = tooltipText;
        parentDom.appendChild(tooltip);
        tooltip.style.cssText = `
          display: inline-block;
          max-width: 500px;
	        max-height: 400px;
          position: fixed;
	        top: ${targetObj.top - 10}px;
          left: ${targetObj.left + (parseFloat(targetObj.width) / 2)}px;
          padding: 10px;
          overflow: auto;
          font-size: 14px;
	        color: #fff;
	        background: rgba(0, 0 , 0, .8);
	        border-radius: 5px;
	        z-index: 19999;
          transform: translate(-50%, -100%);
	      `;
        target.addEventListener('mouseleave', this.removeDom)
      }
    },
    removeDom({target}){
      // console.log(target)
      if (target.getAttribute('tooltip')) {
        setTimeout(() => {
          const tooltip = document.querySelector('.tooltipCls')
          // console.log(tooltip)
          tooltip && parentDom.removeChild(tooltip);
        }, 100);
      }
    }

  },
  beforeDestroy() {
    document.body.removeEventListener('mouseover', this.handleOver)
    document.body.removeEventListener('mouseleave', this.removeDom)
  }
相关推荐
天平1 小时前
油猴脚本创建webworker踩坑记录
前端·javascript·typescript
原则猫3 小时前
前端基础大厦
前端
陈随易4 小时前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart5 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒7 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰7 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
山河木马8 小时前
渲染管线-计算得到gl_Position(顶点着色器)之后续GPU流程
javascript·webgl·图形学
竹林8188 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
妙码生花8 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
Awu12279 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude