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

  • 怎么恢复微信删除的照片和视频(怎么恢复微信删掉的朋友圈)

    怎么恢复微信删除的照片和视频(怎么恢复微信删掉的朋友圈)

  • 荣耀30s支持双频WiFi的吗(荣耀30s支持双频wifi吗)

    荣耀30s支持双频WiFi的吗(荣耀30s支持双频wifi吗)

  • 喜马拉雅账号能同时好几个人登录吗(喜马拉雅账号能不能2个手机登陆)

    喜马拉雅账号能同时好几个人登录吗(喜马拉雅账号能不能2个手机登陆)

  • 华为p20外放声音小(华为p20外放声音小怎么办)

    华为p20外放声音小(华为p20外放声音小怎么办)

  • u盘东西删除不了怎么回事(u盘里的东西删不掉)

    u盘东西删除不了怎么回事(u盘里的东西删不掉)

  • b站设置清晰度不见了(b站怎么设置清晰度)

    b站设置清晰度不见了(b站怎么设置清晰度)

  • 2060super和2070对比(2060super与2070super差距)

    2060super和2070对比(2060super与2070super差距)

  • 拼多多怎么设置拼单人数(拼多多怎么设置支付方式)

    拼多多怎么设置拼单人数(拼多多怎么设置支付方式)

  • 硒鼓带芯片和不带芯片有什么区别(硒鼓带不带芯片是什么意思)

    硒鼓带芯片和不带芯片有什么区别(硒鼓带不带芯片是什么意思)

  • 您拨打的电话正忙是为什么(您拨打的电话正在通话中如需留言请按1)

    您拨打的电话正忙是为什么(您拨打的电话正在通话中如需留言请按1)

  • facetune闪退(faceu闪退怎么回事)

    facetune闪退(faceu闪退怎么回事)

  • 淘宝拍卖保留价是什么意思(淘宝拍卖保留价在哪看)

    淘宝拍卖保留价是什么意思(淘宝拍卖保留价在哪看)

  • 苹果平板插卡版和wifi版有什么区别(苹果平板插卡版可以用wifi吗)

    苹果平板插卡版和wifi版有什么区别(苹果平板插卡版可以用wifi吗)

  • 收音机st和loc什么意思(收音机st loc是什么)

    收音机st和loc什么意思(收音机st loc是什么)

  • 显示器ss接口作用(显示器ss线有什么用)

    显示器ss接口作用(显示器ss线有什么用)

  • 电脑屏幕蓝色什么原因(电脑屏幕 蓝色)

    电脑屏幕蓝色什么原因(电脑屏幕 蓝色)

  • 微信朋友圈置顶怎么设置(微信朋友圈置顶屏蔽的人能看到吗)

    微信朋友圈置顶怎么设置(微信朋友圈置顶屏蔽的人能看到吗)

  • 手机支付宝怎么抢红包(手机支付宝怎么买彩票双色球)

    手机支付宝怎么抢红包(手机支付宝怎么买彩票双色球)

  • 不开网络微信能计步吗(不开网络微信能打电话吗)

    不开网络微信能计步吗(不开网络微信能打电话吗)

  • 抖音怎么复制作者文字(抖音怎么复制作品链接地址)

    抖音怎么复制作者文字(抖音怎么复制作品链接地址)

  • 流量g还是m大(流量g跟m哪个更大)

    流量g还是m大(流量g跟m哪个更大)

  • 如何免费下载QQ音乐付费歌曲(如何免费下载qq付费音乐)

    如何免费下载QQ音乐付费歌曲(如何免费下载qq付费音乐)

  • win10蓝牙怎么开(win10蓝牙怎么开ldac)

    win10蓝牙怎么开(win10蓝牙怎么开ldac)

  • 公司不开票要交工会经费吗
  • 如何查询个人所有贷款记录
  • 公司取得违约金合法吗
  • 融资租赁租出的固定资产需要计提折旧吗
  • 固定资产处置损益科目编码
  • 销售预付卡纳税税率
  • 同一控制企业合并的特征包括
  • 已缴企业所得税公司账户的钱怎么办
  • 出口货物补税申报表
  • 个税专项扣除需要提供哪些依据
  • 外经证缴纳个税流程
  • 事业单位上级拨入资金属于什么科目
  • 补记固定资产
  • 发票折扣有没有限制
  • 企业临时账户是什么意思
  • 银行存款收款凭证
  • 服务费增值税专用发票税点
  • 投资款需要交印花税嘛
  • 开票码是什么意思
  • 怎样算纳税人
  • 关于两套账老板和会计须知的4个点
  • 案例分析关于团员青年的思想困惑疏导和成长问题释疑
  • 公司变更监事需要换营业执照吗?
  • 工伤后辞职了还可以报工伤
  • 公司哪些发票可以做成本或者费用
  • 附加税费减免性质代码
  • 财务报表包含哪些表
  • 小企业递延收益计算公式
  • 运输途中发生货物丢失
  • mac终端更新系统
  • 车辆哪些费用计税
  • 扶贫入股分红政策
  • Windows 2003 SP2 简体中文版下载地址
  • 如何计算经营性负债
  • mp3最早什么年代流行
  • php的转义字符反斜杠
  • 微信小程序四人游戏
  • 车辆购置税退税计算
  • 解决城市内涝的题目
  • 溢价收购股权会计处理案例
  • 锁定vlookup快捷键
  • mysql中regexp_substr函数的使用
  • 客户购买商品的条件?
  • 企业接受捐赠资产属于什么科目
  • mysql唯一键和唯一索引
  • 软件服务费可以全额抵扣吗?
  • 私车公用可以报销哪些费用
  • 工程类企业存货
  • 未开票收入是怎么算的
  • 生产成本怎么结账
  • 营改增会计分录怎么做
  • 红冲发票后如何申报增值税
  • 公司支付宝账户提现需要手续费吗
  • 保险费的增值税属于什么税
  • 哪些行业可以开收购发票
  • 三代个税返还算什么费用
  • 排污费主要用于哪些方面
  • 发票要不回来怎么办
  • 建立备查账的是
  • cgi linux
  • win8本地账户
  • xp系统如何取消开机自动启动程序
  • 苹果macmimi
  • Linux上PPTP VPN的一键安装以及设置开机启动的方法
  • windows8有几个模式
  • linux012
  • JavaScript中的变量名不区分大小写
  • jquery插件怎么写
  • jquery密码验证
  • unity移动ui
  • 置顶高手
  • jquery图片效果
  • 雷爵电动车官网
  • javascript学习指南
  • android java编程
  • 税务登记没去登记会怎么处罚
  • 国家税务总局验证码
  • 婚育证明可以开假的吗
  • 交医保显示已申报怎么办
  • 市中区税务局办税大厅上班时间
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设