Element UI 使用 table 组件设置 el-table-column 宽度width为百分比无效的问题解决方案

问题:

使用 Element el-table 组件时,给列 el-table-column 设置百分比%宽度无效( width="30%" )

解决:

Vue中要将 el-table-column 的宽度设置成百分比的话,不能通过设置 width来实现,而是要设置 min-width,并且每一列都必须设置 min-width

原因:

el-table 组件会被 vue 解析成 html,Vue直接把百分号去掉把数值当做列宽来呈现,所以,width 设置百分比的值直接被解析去掉百分号% 变成 px 了。

需要注意的是:widthmin-width 的原理都是将值百分比去掉变成 px。可是 min-width 会按照比例分配剩余空间,并非直接算的百分比。(因此要每一列都设置 min-width 才能实现每一列的百分比配置)设置成 min-width 以后,width 的值就被计算成 (当前值 / 全部列值和)的百分比了。

这里我倒觉得设计的挺好的,在 html 中使用 width 设置百分比的时候总要关心其总和需要是 100%,维护起来也比较麻烦,而这种设置百分比并不需要其总和为100%,我觉得这是一项改进。

示例:

<el-table v-loading="loading" :data="tableData">
	<el-table-column prop="id" label="ID" min-width="6%"></el-table-column>
	<el-table-column prop="name" label="姓名" min-width="12%"></el-table-column>
	<el-table-column prop="create_time" label="创建时间" min-width="24%"></el-table-column>
	<el-table-column prop="update_time" label="更新时间" min-width="24%"></el-table-column>
</el-table>
  • 31
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值