在VUE3+Element-plus中的el-table实现单元格内超出内容提示功能

在完成公司业务的时候,表格内容太多会撑开,不太美观,需要做一些优化,发现有一些部分还是需要探讨一下。

1.Table-column 自带属性

在Table-column 属性中有个属性

show-overflow-tooltip当内容过长被隐藏时显示 tooltip

貌似可以直接实现该功能,但有两个缺点

(1)隐藏后只能一行显示,想多行省略加入样式

 text-overflow: ellipsis;
 overflow: hidden;
 display: -webkit-box;
 -webkit-line-clamp: 9;
 -webkit-box-orient: vertical;

之后提示会不生效了,因为自带属性的提示是根据宽度来进行判断了,而该样式是根据高度进行判断

(2)表格内容不能嵌套,否则同样样式不会生效,有格式要求非常不方便

2.利用el-tooltip组件

直接上代码

html部分

 		<el-tooltip
            placement="top-start"
            effect="light"
            :disabled="latestTooltipFlag"
            enterable
          >
            <template #content>
              <div class="last_commoner-tip">
               <--提示内容-->
              </div>
            </template>
            <div
              class="last_commoner"
              ref="latest_apm_visit"
              @mouseenter="latestChange(latest_apm_visit[scope.$index])"
            >
             <--展示内容-->
            </div>
          </el-tooltip>

js部分

const latest_apm_visit = ref();
const latestChange = (event: any) => {
  if (event.clientHeight < event.scrollHeight) {
    latestTooltipFlag.value = false;
  } else {
    latestTooltipFlag.value = true;
  }
};

css部分

.last_commoner-tip {
  width: 380px;
}
.last_commoner {
  text-overflow: ellipsis;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 9; //改变数字显示几行
  -webkit-box-orient: vertical;
}

原理:通过css设置后,可以判断出元素的clientHeight与scrollHeight是不同的值,通过判断他们的大小,来判断提示是否进行提示,而表格内容会同时出现多个元素所以这里加入了ref,并且通过scope.$index知道是第几个元素,然后通过mouseenter事件进行传值实现,该功能就完成了,可以随意改变显示行数,只需改变-webkit-line-clamp属性即可。

其实看似方便同样也有缺点,每设置一列都需要加上上面一串代码,想要进行封装但是由于ref的存在,封装难度加大,各位大佬如果有好的封装方法欢迎解答。

由于感觉不是最优解法,于是打算尝试换种优化,不再超出内容展示了,而是点击展示所有内容,由省略到展示全部。实现并不难,这里不再赘述了,如果各位大佬有更好的方法,欢迎交流。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

时雨.`

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值