解决elementui表格操作列自适应列宽


Posted in Javascript onDecember 28, 2020

业务需要前端根据用户权限动态显示对应按钮,直接把操作列的列宽写死的话,在按钮少的情况下不是那么好看,所以想到了一个骚操作...

写死宽度时是这样的:

解决elementui表格操作列自适应列宽

开始

给操作列绑定宽度属性

:width="actionColWidth < 80 ? 80 : actionColWidth"

把操作列的所有按钮用一个div套起来

class="action-col"

<div class="action-col">
 <el-button></el-button>
 ...
</div>

data里设置列宽初始值

actionColWidth: 80, //表格操作列宽度

在表格数据请求回来赋值给表格之后,执行计算宽度的操作

这里是用jq获取表格第一行的全部按钮,然后把每个按钮的宽度加起来,就是操作列的宽度。

不用jq的话用原生js也行。

如果表格每一行的操作按钮是不一样的,那么就获取每一行操作按钮的总宽度,然后取最大的就行。这里没有这个需求,就不写了。

getClerkList(params)
 .then((res) => {
  this.tableData = res.rows;

  this.$nextTick(() => {
  // 给表格操作列宽度多出25px,否则显示不完整
  let width = 25;
  // 使用jq遍历表格第一行操作列里的每一个按钮
  $(".action-col")
   .eq(0)
   .children(".el-button")
   .each(function () {
   // 把每个按钮的宽度加起来
   width += $(this).outerWidth(true);
   });
  // 把计算好的总宽度赋值给操作列宽
  this.actionColWidth = width;
  });
 })
 .catch((err) => {
  console.error(err);
 });

看一下效果

没有按钮时:

解决elementui表格操作列自适应列宽

有一个按钮:

解决elementui表格操作列自适应列宽

有两个按钮:

解决elementui表格操作列自适应列宽

有三个按钮:

解决elementui表格操作列自适应列宽

到此这篇关于解决elementui表格操作列自适应列宽的文章就介绍到这了,更多相关elementui表格自适应列宽内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
JavaScript实现禁止后退的方法
Dec 27 Javascript
浅析LigerUi开发中谨慎载入common.css文件
Jul 09 Javascript
JavaScript实现复制或剪切内容到剪贴板功能的方法
May 23 Javascript
JS实现的相册图片左右滚动完整实例
Nov 23 Javascript
jQuery实现鼠标滑过图片移动特效
Dec 08 Javascript
JS简单验证上传文件类型的方法
Apr 17 Javascript
详解vue-cli中配置sass
Jun 21 Javascript
使用JavaScript实现一个小程序之99乘法表
Sep 21 Javascript
Layui表格行工具事件与数据回填方法
Sep 13 Javascript
Vue实现浏览器打印功能的代码
Apr 17 Javascript
鸿蒙系统中的 JS 开发框架
Sep 18 Javascript
解决vue-loader加载不上的问题
Oct 21 Javascript
微信小程序视频弹幕发送功能的实现
Dec 28 #Javascript
React实现todolist功能
Dec 28 #Javascript
mustache.js实现首页元件动态渲染的示例代码
Dec 28 #Javascript
11个Javascript小技巧帮你提升代码质量(小结)
Dec 28 #Javascript
vue中watch的用法汇总
Dec 28 #Vue.js
浅析vue中的nextTick
Dec 28 #Vue.js
js仿淘宝放大镜效果
Dec 28 #Javascript
You might like
PHP中读取文件的8种方法和代码实例
2014/08/05 PHP
php+mongodb判断坐标是否在指定多边形区域内的实例
2016/10/28 PHP
PHP连续签到功能实现方法详解
2019/12/04 PHP
javascript不同页面传值的改进版
2008/09/30 Javascript
js控制div及网页相关属性的代码
2009/12/19 Javascript
javascript 精粹笔记
2010/05/09 Javascript
简单的Jquery全选功能
2013/11/07 Javascript
jquery基础教程之数组使用详解
2014/03/10 Javascript
javascript跨浏览器的属性判断方法
2014/03/16 Javascript
Nodejs中的this详解
2016/03/26 NodeJs
ReactNative-JS 调用原生方法实例代码
2016/10/08 Javascript
详解VueJs异步动态加载块
2017/03/09 Javascript
Js自定义多选框效果的实例代码
2017/07/05 Javascript
vue中 this.$set的用法详解
2019/09/06 Javascript
webgl实现物体描边效果的方法介绍
2019/11/27 Javascript
js实现无缝轮播图效果
2020/03/09 Javascript
python编程实现希尔排序
2017/04/13 Python
Python科学计算包numpy用法实例详解
2018/02/08 Python
python实时检测键盘输入函数的示例
2019/07/17 Python
Python实现一个带权无回置随机抽选函数的方法
2019/07/24 Python
wxpython多线程防假死与线程间传递消息实例详解
2019/12/13 Python
Python列表倒序输出及其效率详解
2020/03/04 Python
python的json包位置及用法总结
2020/06/21 Python
html5手机端页面可以向右滑动导致样式受影响的问题
2018/06/20 HTML / CSS
韩国CJ食品专卖网:CJonmart
2016/09/11 全球购物
ProForm英国站点:健身房和健身器材网上商店
2019/06/05 全球购物
俄罗斯童装网上商店:BebaKids
2020/06/06 全球购物
采购类个人求职的自我评价
2014/02/18 职场文书
舞蹈毕业生的自我评价
2014/03/05 职场文书
新书发布会策划方案
2014/06/09 职场文书
终止或解除劳动合同及劳动关系的证明书
2014/10/06 职场文书
团代会开幕词
2015/01/28 职场文书
污染环境建议书
2015/09/14 职场文书
2016年学校党支部创先争优活动总结
2016/04/05 职场文书
python生成可执行exe控制Microsip自动填写号码并拨打功能
2021/06/21 Python
Java 超详细讲解十大排序算法面试无忧
2022/04/08 Java/Android