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)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值