位置: 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官网)

  • 销项税额和进项税额发票怎么区别
  • 什么是货物运输保险
  • 平行结转分步法各步骤的费用
  • 个体工商户营业执照年检网上申报
  • 预缴的附加税月末结转吗
  • 季末资产总额的计算
  • 开具16个点发票情况说明
  • 报关单找不到了怎么办
  • 小微企业免征的增值税要交所得税吗
  • 境外机构可以开通b股账户
  • 销售自己使用过的物品免税吗
  • 怎么控制成本费用餐厅
  • 哪些补贴可以不交个税
  • 投标公司资质借用计入什么会计科目?
  • 预付账款下月做什么科目
  • 生产车间计提固定资产折旧会计科目
  • 城建税当月缴纳要计提吗
  • 小规模纳税人差额征税
  • 营改增挂靠工程项目账务处理
  • 出差餐费报销怎么报销
  • 外包的人力费用包括哪些
  • 进项税额转出的会计分录
  • 税控盘登不上怎么回事
  • 遇到境外网络勒索敲诈怎么办
  • 增值税的征收范围包括在中华人民共和国境内
  • 汇算清缴专项附加扣除去年忘记填的能补填吗?
  • 被替换的账面价值题目
  • 企业给予的折扣怎么入账
  • 查账补缴的税的账怎么做
  • php快速查找
  • 留抵税额抵扣会计分录
  • 王者营地怎么转移到安卓系统
  • 特许经营企业广告语
  • PHP:realpath_cache_get()的用法_Filesystem函数
  • 库存商品出库怎么计算
  • 购买材料支出明细表
  • yii框架教程
  • java分页page类
  • 实名办税人员承担什么责任
  • css中哪些属性可以使用
  • 本地存储localstorage没有拿到最新值
  • bert数据增强
  • mapbox怎么用
  • 进口货物没有发票怎么入账,报税时怎么填
  • 不良品扣款应入哪个科目
  • 税控盘全额抵扣发票怎么勾选
  • 资产处置损益是什么类
  • 建筑业成本需要摊销吗
  • 增值税申报表是含税还是不含税
  • 企业所得税法允许按规定的比例在税前扣除的准备金
  • 土地增值税的预征和清算
  • 建筑业发票可以抵扣制造业进项
  • 给职工交的商业险是什么
  • 怎么填写专用发票信息
  • 红字冲销凭证怎么登明细账
  • 会计做账工作总结
  • 公司坏账率一般多少
  • mysql触发器的作用
  • mac 特殊符号
  • ubuntu14升级
  • scanregistry.exe - scanregistry是什么进程 有什么用
  • centos soft lockup
  • Win7系统可以装ie10浏览器么
  • win7无法保存对权限所作的更改
  • linux虚拟空间
  • cdn ajax
  • 批处理文件是可执行文件吗
  • 用javascript
  • 有道词典下载安装
  • android车载导航刷机包
  • linux pop
  • js显示word
  • javascrip语言
  • jquery文档处理有哪些
  • android listview数据动态加载
  • flask框架官方文档
  • 交通运输业的税率9%和13%
  • 福建医保省外报销政策
  • 全国大学生数学竞赛证书电子版查询
  • 结售汇选择汇还是钞好
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设