位置: IT常识 - 正文

自定义vue指令,实现el-tooltip仅在文字溢出时显示,文字未溢出则不显示,复制即可使用(vue3自定义指令)

编辑:rootadmin
自定义vue指令,实现el-tooltip仅在文字溢出时显示,文字未溢出则不显示,复制即可使用 一、写在开头

推荐整理分享自定义vue指令,实现el-tooltip仅在文字溢出时显示,文字未溢出则不显示,复制即可使用(vue3自定义指令),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue3.0自定义指令,vuejs自定义指令,自定义vue指令,vuecli自定义指令,vue3自定义指令,自定义vue指令,vue3.0自定义指令,自定义vue指令,内容如对您有帮助,希望把文章链接给更多的朋友!

在项目里遇到了这种需求,想到el-table里的show-overflow-tooltip属性就有这种效果,在参考了一些网上的文章以及show-overflow-tooltip跟el-tooltip的源码后,觉得使用自定义指令的方式来实现这个需求会很方便,于是便有了以下代码

二、自定义指令代码1、创建一个js文件,复制粘贴以下代码即可使用,无需改动import Vue from 'vue'import debounce from 'throttle-debounce/debounce'import { Tooltip } from 'element-ui'Vue.use(Tooltip)/*** 指令功能:元素内容溢出隐藏时悬浮tooltip展示详细内容,元素内容未溢出时不展示* 基于element-table的show-overflow-tooltip原理与el-tooltip的功能实现* 使用方式:* <div v-overflow-tooltip>这是一段会溢出的文本内容</div>** 指令也可传递参数,参数内容为el-tooltip的参数配置:* <div v-overflow-tooltip="{content:'啦啦啦啦~~~'}">这是一段会溢出的文本内容</div>* *//*** tooltipVM —— el-tooltip的VNode实例* tooltipContent —— 默认提示文本内容* props —— el-tooltip的配置参数* ctx —— 命名空间* activateTooltip —— el-tooltip展开的防抖延迟,默认50ms* */let tooltipContentlet propsconst ctx = '@@store'// 创建一个Vue实例并渲染为真实DOM,内有一个空的el-tooltip组件const vm = new Vue({render (h) {return (<Tooltip ref="customToolTipRef" content={ tooltipContent } { ...{ props } }></Tooltip>)}}).$mount()const tooltipVM = vm.$refs.customToolTipRefconst activateTooltip = debounce(50, tooltipVM => tooltipVM.handleShowPopper())const overflowHandler = (el, binding, vnode) => {// 获取元素文本内容,作为el-tooltip的默认content进行展示el[ctx].tooltipContent = el.innerText || el.textContent// 获取通过指令接收的绑定值el[ctx].props = { ...binding.value }const computedStyle = getComputedStyle(el)// 使用range对象判断文本是否有溢出,优先考虑使用range对象, 因为 scrollWidth 属性在火狐浏览器 v32 版本中有 bug。当元素的 CSS 属性中使用了 text-overflow: ellipsis 和 box-sizing: border-box 时获取到的 scrollWidth 的值会比真实值偏小const range = document.createRange()range.setStart(el, 0)range.setEnd(el, el.childNodes.length)const rangeDOM = range.getBoundingClientRect()const padding = parseInt(computedStyle.paddingLeft.replace('px', '')) + parseInt(computedStyle.paddingRight.replace('px', ''))const rangeWidth = Math.round(rangeDOM.width)if (rangeWidth + padding > el.offsetWidth || el.scrollWidth > el.offsetWidth) {// 文本溢出了,绑定鼠标事件el.addEventListener('mouseenter', el[ctx].handleMouseEnter)el.addEventListener('mouseleave', el[ctx].handleMouseLeave)} else {// 文本未溢出,移除鼠标事件el.removeEventListener('mouseenter', el[ctx].handleMouseEnter)el.removeEventListener('mouseleave', el[ctx].handleMouseLeave)}}Vue.directive('overflowTooltip', {// 只调用一次,指令第一次绑定到元素时调用。在这里进行一次初始化设置,初始化鼠标事件,控制el-tooltip的展开与收起bind: function (el, binding, vnode) {el[ctx] = {tooltipContent: '',props: {},handleMouseEnter: () => {// 展开el-tooltip方法,将el-tooltip的引用元素指向当前绑定节点,然后执行展开逻辑tooltipContent = el[ctx].tooltipContentprops = el[ctx].propsvm.$forceUpdate()tooltipVM.referenceElm = eltooltipVM.$refs.popper && (tooltipVM.$refs.popper.style.display = 'none')tooltipVM.doDestroy()tooltipVM.setExpectedState(true)activateTooltip(tooltipVM)},handleMouseLeave: () => {// 关闭el-tooltip方法,销毁内部popperJS的实例后走关闭逻辑tooltipVM.doDestroy()tooltipVM.setExpectedState(false)tooltipVM.handleClosePopper()}}},inserted: overflowHandler,componentUpdated: overflowHandler,unbind (el) {delete el[ctx]}})2、使用方法2.1. 默认无参数用法自定义vue指令,实现el-tooltip仅在文字溢出时显示,文字未溢出则不显示,复制即可使用(vue3自定义指令)

没有传递值给指令的时候,将使用el-tooltip的默认配置,提示内容默认显示指令绑定元素的文本内容

<el-input v-model="value" placeholder="请输入内容" style="width: 200px; margin-bottom: 25px"></el-input><div v-overflow-tooltip class="overflow">{{ value }}</div>

默认效果

2.2. 自定义传递参数用法

参数内容其实就是el-tooltip官方定义可以传递的配置参数,我们可以自定义内容、主题、显示位置等

<el-input v-model="value" placeholder="请输入内容" style="width: 200px; margin-bottom: 25px"></el-input><div v-overflow-tooltip="{content:'这是通过content自定义的溢出显示内容',effect:'light'}" class="overflow">{{ value }}</div>

自定义参数效果

三、实现原理简述

不了解自定义指令的小伙伴可以看一下我在文末分享的链接。

最开始我们需要创建一个tooltip的vue实例,以及其他的一些空变量为后续内容做准备。此处为了方便,vue实例中使用了JSX语法,大家可以根据需求更换为h函数(createElement)的写法。

本文链接地址:https://www.jiuchutong.com/zhishi/284052.html 转载请保留说明!

上一篇:如何像专业人员那样在openSUSE上安装和更新软件?opensuse安装软件详细教程(如何使专业人员的工作卓有成效读后感悟)

下一篇:YOLOv5/v8改进主干GhostNetV2系列:首发结合最新NIPS2022华为诺亚的GhostNetV2 架构:引入长距离注意力机制增强廉价操作,构建更强端侧轻量型骨干,打造高效轻量级检测器(改进yolov4)

  • 人力资源外包可以选择简易计税吗
  • 注册会计师考试时间2023
  • 出货一般要多久
  • 增值税零申报怎么报税
  • 科技人员股权奖励
  • 收到失控发票写情况说明
  • 转让无形资产专利权的账务处理
  • 制造企业发出材料成本的计价方法
  • 有限合伙企业分红个人所得税
  • 用友软件作废凭证
  • 装修职工宿舍用的瓷砖,灯具等计入什么科目?
  • 银行承兑汇票贴现怎么算
  • 增值税开票员的岗位职责
  • 苗木增值税发票税率
  • 员工旅游费需要缴纳个人所得税吗
  • 增值税滞留票产生的原因及处理办法
  • 劳务分包简易计税可以抵扣吗
  • 税金及附加期末结转分录
  • 残保金和工会经费需要计提吗
  • 副调基金的会计分录怎么做?
  • 发票金额大于实际支付金额如何报账
  • 简易计税发票如何抵扣
  • 路由器和光猫上的无线网络名称一样吗
  • win1020h2更新0x800f081f
  • 模具成本怎么核算
  • thinkphp 3.2.3 getshell
  • php string
  • win11怎么清理电脑垃圾
  • php imagestring
  • 进货后退货的会计处理
  • 固定资产清理损失可以税前扣除吗
  • phpexcel插件
  • 股权激励费用摊销计算
  • 公司报亏损需要交税吗
  • php加密后的代码能运行吗?
  • 怎么查商品的税率
  • clh锅
  • php使用什么开发工具
  • 增值税发票认证抵扣时间规定
  • 下载vue2
  • php的序列化操作生成的哪种格式
  • 金融机构拆出资金的最长期限
  • 增值税普通发票查询真伪
  • 申请税控盘流程需要几个工作日
  • 帝国cms如何使用
  • 小规模纳税人工资薪金怎么申报
  • 水电费用属于会计的什么费用
  • sql server2000中事务的类型有
  • sql2005安装步骤
  • sql chr函数
  • MySQL读写分离企业方案
  • mysql中删除语句怎么写
  • 核定征收无收入
  • 公司发放工作服怎么做账务处理
  • 怎么查公司的对公账户
  • 出库销售会计分录
  • 工资补偿款是什么意思
  • 金蝶旗舰版的数据怎么在标准版打开
  • 员工报销停车费计入什么科目
  • 其他债权投资发生减值会影响所有者权益总额吗
  • 外经证核销反馈表写错了怎么办
  • 管理费用贷方有余额怎么处理
  • 重大影响包括50%吗
  • 零售商品销售的具体核算步骤
  • win10系统崩溃怎么修复开不了机
  • 解决windows hello人脸识别找不到摄像头
  • windows server 2008 r2开启远程访问
  • windows service 2008 r2
  • rhel7.4安装
  • ie11怎么打开ie8
  • centos6.10安装
  • windows7软件卸载
  • win8 metro启动界面
  • 微软windows8.1
  • unity飞机大战游戏毕业论文
  • javascript基础教程pdf
  • 多个javascript 合并
  • 谷歌的全球化发展战略
  • 呼伦贝尔清欠办电话
  • 购房合同交契税怎么交
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设