vue管理系统(element-admin)在render函数中使用指令
问题描述
需求:table列表中文字溢出隐藏,并且隐藏的文字要使用title提示。
问题分析
- 需要一个title提示的指令或者方法
- 在table列表的数据中使用这个指令或方法
问题解决
- 写了一个全局指令, 如果文字溢出了就提示title,如果文字没有溢出就不显示title。
// 溢出隐藏显示title
Vue.directive('title', {
inserted: function (el, binding) {
let padding = binding.value || 24
el.addEventListener('mouseenter', (evt) => {
let target = evt.target
const { offsetWidth, title } = target // 目标元素宽
let clientWidth = 10000
if (evt.fromElement) {
clientWidth = evt.fromElement.clientWidth - padding // 父元素宽
}
target.title = target.innerText
if (offsetWidth < clientWidth) target.title = ""
})
}
})
- 在table中使用这个指令(table没有封装)
<!-- v-title="50" 如果table的cellpadding过大可以给title绑定一个值来实现溢出提示效果 -->
<el-table-column label="名称" prop="name">
<template slot-scope="{ row }">
<span v-title>{{ row.name }}</span>
</template>
</el-table-column>
- 在table中使用这个指令(table封装成组件)
// 注意在render一个span时,添加一个directives对象,其中的name就是全局注册的 title 指令。
return h('span', {directives: [{name:'title'}]}, name)
分类:
vue
, element ui
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构