vue自定义指令,表格内文字超出显示提示tooltip

export default {
	// el {element} 当前元素
	componentUpdated (el, binding, vnode) {
	  const curStyle = window.getComputedStyle(el, '') // 获取当前元素的style
	  const textSpan = document.createElement('span') // 创建一个容器来记录文字的width
	  // 设置新容器的字体样式,确保与当前需要隐藏的样式相同
	  textSpan.style.fontSize = curStyle.fontSize
	  textSpan.style.fontWeight = curStyle.fontWeight
	  textSpan.style.fontFamily = curStyle.fontFamily
	  // 将容器插入body,如果不插入,offsetWidth为0
	  document.body.appendChild(textSpan)
	  // 设置新容器的文字
	  textSpan.innerHTML = el.innerText
	  // 如果字体元素大于当前元素,则需要隐藏
	  if (textSpan.offsetWidth > el.offsetWidth) {
	    // 给当前元素设置超出隐藏
	    el.style.overflow = 'hidden'
	    el.style.textOverflow = 'ellipsis'
	    el.style.whiteSpace = 'nowrap'
	    // 鼠标移入
	    el.onmouseenter = function (e) {
	      // 创建浮层元素并设置样式
	      const vcTooltipDom = document.createElement('div')
	      vcTooltipDom.style.cssText = `
	        max-width:400px;
	        max-height: 400px;
	        overflow: auto;
	        position:absolute;
	        top:${e.clientY + 5}px;
	        left:${e.clientX}px;
	        background: rgba(0, 0 , 0, .6);
	        color:#fff;
	        border-radius:5px;
	        padding:10px;
	        display:inline-block;
	        font-size:14px;
	        z-index:19999
	      `
	      // 设置id方便寻找
	      vcTooltipDom.setAttribute('id', 'vc-tooltip')
	      // 将浮层插入到body中
	      document.body.appendChild(vcTooltipDom)
	      // 浮层中的文字
	      document.getElementById('vc-tooltip').innerHTML = el.innerText
	    }
	    // 鼠标移出
	    el.onmouseleave = function () {
	      // 找到浮层元素并移出
	      const vcTooltipDom = document.getElementById('vc-tooltip')
	      vcTooltipDom && document.body.removeChild(vcTooltipDom)
	    }
	  }
	  // 记得移除刚刚创建的记录文字的容器
	  document.body.removeChild(textSpan)
	},
	// 指令与元素解绑时
	unbind () {
	  // 找到浮层元素并移除
	  const vcTooltipDom = document.getElementById('vc-tooltip')
	  vcTooltipDom && document.body.removeChild(vcTooltipDom)
	}
}

#在main.js中引入

import showTips from './directive/permission/showtip'

Vue.directive('showTips', showTips)
在表格中使用
<el-table-column label="详情" align="center" prop="warnInfo" >
  <template slot-scope="scope">
	<span v-show-tips>{{ scope.row.warnInfo }}</span>
  </template>
</el-table-column>
  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值