位置: IT常识 - 正文

Element UI 扩展tooltip 只在内容过长才显示(element插件安装方法)

编辑:rootadmin
Tooltip常用于展示鼠标 hover 时的提示信息。而在实际过程中,有这么一个需求:只有文字内容排不下,出现省略号,才需要显示tooltip的提示内容。本文章的思路是通过一个自定义指令实现如下效果:姓名字段过长时才显示tooltip ... 1. 介绍

推荐整理分享Element UI 扩展tooltip 只在内容过长才显示(element插件安装方法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:elementui插件,elementui插件,element ui tooltip,elementui扩展组件,elementui扩展组件,element ui 插槽,element ui 插槽,element扩展组件,内容如对您有帮助,希望把文章链接给更多的朋友!

Tooltip常用于展示鼠标 hover 时的提示信息。

而在实际过程中,有这么一个需求:只有文字内容排不下,出现省略号,才需要显示tooltip的提示内容。

本文章的思路是通过一个自定义指令实现如下效果:姓名字段过长时才显示tooltip

2.element-ui(vue2版本)2.1 注册指令1)akTooltipAutoShow.jsElement UI 扩展tooltip 只在内容过长才显示(element插件安装方法)

说明:注册了一个名称为 'ak-tooltip-auto-show' 的指令。会根据内容进行判断是否展示tooltip。

import Vue from 'vue';import { on, off, getStyle } from 'element-ui/src/utils/dom';/*** ak-tooltip-auto-show* 当text没有被折叠时,不显示tooltip*/Vue.directive('ak-tooltip-auto-show', {inserted: function (el, binding, vnode) {el.addEventListener('mouseenter', function (e) {let defalutSilent = !!Vue.config.silent;Vue.config.silent = true;vnode.componentInstance.disabled = true;const range = document.createRange();range.setStart(el, 0);range.setEnd(el, el.childNodes.length);const rangeWidth = Math.round(range.getBoundingClientRect().width);const padding = (parseInt(getStyle(el, 'paddingLeft'), 10) || 0) + (parseInt(getStyle(el, 'paddingRight'), 10) || 0);if (rangeWidth + padding > el.offsetWidth || el.scrollWidth > el.offsetWidth) {vnode.componentInstance.disabled = false;}Vue.config.silent = defalutSilent;});}});2.2 使用

说明:使用<el-tooltip v-ak-tooltip-auto-show>包囊展示的内容。

<div class="details-inner__row"><span class="details-inner__row-name">姓名:</span><el-tooltip placement="top" effect="dark" :content="item.name" v-ak-tooltip-auto-show><span class="details-inner__row-value">{{item.name}}</span></el-tooltip></div>// css.details-inner__row-value {  width: 80%;  display: inline-block;  white-space: nowrap;  text-overflow: ellipsis;  overflow: hidden;}

  

3. element-plus(vue3版本)3.1 注册指令1)akTooltipAutoShow.js

说明:注册了一个名称为 'ak-tooltip-auto-show' 的指令。会根据内容进行判断是否展示tooltip。

注意:因为element-plus与之前的element-ui不一样,在element-plus(vue3版本)中是 <展示组件>包含<el-tooltip>的,所以代码中需要在<展示组件>内查找<el-tooltop>。

import { getStyle } from 'element-plus/lib/utils/dom/index';/*** show-overflow-tooltip for text* 当text没有被折叠时,不显示tooltip*/const akTooltipAutoShow = {created(el, binding, vnode) {let tooltipNode = vnode.children.find((childrenCmpt) => childrenCmpt.component?.type.name == 'ElTooltip');if (tooltipNode) {let { content } = tooltipNode.props;if (content && ['添加', '编辑', '删除','查看'].includes(content)) {el.addEventListener('click', function (e) {let defalutDisabled = tooltipNode.component.props.disabled;if (!defalutDisabled) {tooltipNode.component.props.disabled = true;setTimeout(() => {tooltipNode.component.props.disabled = defalutDisabled;}, 200);}});} else {el.addEventListener('mouseenter', (e) => {tooltipNode.component.props.disabled = true;const range = document.createRange();range.setStart(el, 0);range.setEnd(el, el.childNodes.length);const rangeWidth = Math.round(range.getBoundingClientRect().width);const padding = (parseInt(getStyle(el, 'paddingLeft'), 10) || 0) + (parseInt(getStyle(el, 'paddingRight'), 10) || 0);if (rangeWidth + padding > el.offsetWidth || el.scrollWidth > el.offsetWidth) {tooltipNode.component.props.disabled = false;}});}}}};export default akTooltipAutoShow;2) 进行局部或全局注册// main.jsconst app = createApp(App);import akTooltipAutoShow from './akTooltipAutoShow.js';app.directive('ak-tooltip-auto-show', akTooltipAutoShow);

  

3.2 使用

说明:因element-plus(vue3版本)本身不提供 root element,所以需要把此指令放到<el-tooltip>的父级组件。

<div class="details-inner__row">  <span class="details-inner__row-name">姓名:</span>  <span class="details-inner__row-value" v-ak-tooltip-auto-show>    <el-tooltip placement="top-end" :content="item.name">{{item.name}}</el-tooltip>  </span></div>// css.details-inner__row-value {  width: 80%;  display: inline-block;  white-space: nowrap;  text-overflow: ellipsis;  overflow: hidden;}

  

End Web开发之路系列文章 菜单加载中...
本文链接地址:https://www.jiuchutong.com/zhishi/304713.html 转载请保留说明!

上一篇:phpcms api怎么写接口(phpcms开发手册)

下一篇:phpcms v9怎么安装(phpcms v9官网)

  • 报完增值税就要清卡吗
  • 协定税率的简称
  • 交易性金融资产的交易费用计入哪里
  • 税收专用缴款书
  • 解除合同补偿金需要缴纳个税吗
  • 一般纳税人抵扣小规模期间的专票怎么解决
  • 企业用银行存款购买原材料
  • 开票系统维护费计入什么科目
  • 核定征收所得税税率
  • 股票回购后多久注销
  • 年末增值税结转账务处理流程
  • 装修公司能开增值发票吗
  • 个人股权转让申报表
  • 计提增值税附加税的会计科目
  • 邮政通信业
  • 电商退款
  • 污水处理服务费用交印花税吗
  • 企业会计准则固定资产解释
  • linux系统怎么查看mac地址
  • 二手车增值税专用发票税率
  • vue大屏组件库
  • win11 pin失效
  • 没有组策略权限
  • 收到进项税发票如何入账
  • 单位交社保是不是比个人交社保以后退休金要多
  • 加速折旧法计算公式 CFA
  • zhp.exe是什么进程
  • gst插件
  • 有限责任公司股东会的职权有哪些?
  • 供热企业税收优惠政策
  • 两借两贷属于复合会计分录吗
  • php实现登录功能
  • php判断https
  • springboot集成clickhouse
  • react组件定义
  • 自动驾驶感知算法
  • elasticsearch基本概念
  • 季度盈利弥补亏损利润表
  • css content \f041
  • 累计折旧累计摊销属于现金流吗
  • 连锁店会计的工作内容
  • 认缴出资和实缴出资时间怎么填
  • 多缴所得税怎么算
  • mockito mock方法
  • 购买仪器属于什么费用
  • 个人社保的缴纳时间
  • 向银行申请银行汇票
  • 工会记账凭证怎么记
  • 弥补以前年度亏损后怎么交所得税
  • mysql命令行怎么用
  • 取得费用报销单怎么填写
  • 契税是指什么?
  • 工资与社保的关系图
  • 小额贷款公司ei
  • 医院药品进销差价会计核算
  • 费用支出多了怎么办
  • 管理费用如何结转成本
  • 一般纳税人购入固定资产进项抵扣
  • 公司章程上的出资额怎么填
  • 小企业会计准则会计科目表
  • 非营利医疗机构什么意思
  • 新企业设置账簿
  • mysql事件调用存储过程
  • u盘怎么设置速度快
  • win10预览体验三个选项
  • win7系统注册表损坏无法启动
  • win8找不到恢复环境怎么恢复出厂设置
  • JS实现的base64加密解密完整实例
  • android开发工程师案例教程源码
  • python生成密钥
  • 网关绑定失败怎么设置
  • ubuntu20.04怎么安装
  • 北京海淀区国税有几个办税大厅?
  • 责令立即改正和责令限期整改
  • 北京 国税
  • 地税局是政府部门吗
  • 办公室租金可以开专票抵扣进项税吗
  • 镇江市税务局官网
  • 定额发票作废了还能报销吗
  • 印花税应税凭证数量是什么意思
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设