解决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实现动态增加删除表格行(兼容IE/FF)
Apr 02 Javascript
window.dialogArguments 使用说明
Apr 11 Javascript
jquery each的几种常用的使用方法示例
Jan 21 Javascript
node.js中的fs.unlinkSync方法使用说明
Dec 15 Javascript
jQuery搜索同辈元素方法
Feb 10 Javascript
简单谈谈JavaScript的同步与异步
Dec 31 Javascript
BootstrapTable+KnockoutJS自定义T4模板快速生成增删改查页面
Aug 01 Javascript
jquery图片放大镜效果
Jun 23 jQuery
微信小程序API—获取定位的详解
Apr 30 Javascript
JS多个异步请求 按顺序执行next实现解析
Sep 16 Javascript
html2canvas属性和使用方法以及如何使用html2canvas将HTML内容写入Canvas生成图片
Jan 12 Javascript
Element Badge标记的使用方法
Jul 27 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
destoon会员注册提示“数据校验失败(2)”解决方法
2014/06/21 PHP
PHP实现的一致性哈希算法完整实例
2015/11/14 PHP
Zend Framework生成验证码并实现验证码验证功能(附demo源码下载)
2016/03/22 PHP
PHP发送AT指令实例代码
2016/05/26 PHP
php+ajax简单实现全选删除的方法
2016/12/06 PHP
PHP根据树的前序遍历和中序遍历构造树并输出后序遍历的方法
2017/11/10 PHP
自写简单JS判断是否已经弹出页面
2010/10/20 Javascript
拖动table标题实现改变td的大小(css+js代码)
2013/04/16 Javascript
JavaScript中提前声明变量或函数例子
2014/11/12 Javascript
jQuery构造函数init参数分析续
2015/05/13 Javascript
非常实用的12个jquery代码片段
2015/11/02 Javascript
JS实现密码框根据焦点的获取与失去控制文字的消失与显示效果
2015/11/26 Javascript
基于JavaScript将表单序列化类型的数据转化成对象的处理(允许对象中包含对象)
2015/12/28 Javascript
Node.js学习入门
2017/01/03 Javascript
JS 实现 ajax 异步浏览器兼容问题
2017/01/21 Javascript
JS字符串按逗号和回车分隔的方法
2017/04/25 Javascript
实现div内部滚动条滚动到底部和顶部的代码
2017/11/15 Javascript
JavaScript实现异步图像上传功能
2018/07/12 Javascript
jQuery实现数字自动增加或者减少的动画效果示例
2018/12/11 jQuery
基于node简单实现RSA加解密的方法步骤
2019/03/21 Javascript
中级前端工程师必须要掌握的27个JavaScript 技巧(干货总结)
2019/09/23 Javascript
node解析修改nginx配置文件操作实例分析
2019/11/06 Javascript
使用webpack搭建vue环境的教程详解
2019/12/31 Javascript
vue中选中多个选项并且改变选中的样式的实例代码
2020/09/16 Javascript
python发送伪造的arp请求
2014/01/09 Python
Python实现遍历windows所有窗口并输出窗口标题的方法
2015/03/13 Python
Python EOL while scanning string literal问题解决方法
2020/09/18 Python
ubuntu中配置pyqt4环境教程
2017/12/27 Python
python实现一个简单的udp通信的示例代码
2019/02/01 Python
pytorch查看torch.Tensor和model是否在CUDA上的实例
2020/01/03 Python
美国卡车、吉普车和SUV零件网站:4 Wheel Parts
2016/11/24 全球购物
美国NBA官方商店:NBA Store
2019/04/12 全球购物
餐饮加盟计划书
2014/01/10 职场文书
乡镇爱国卫生月活动总结
2014/06/25 职场文书
Python中使用ipython的详细教程
2021/06/22 Python
vue ant design 封装弹窗表单的使用
2022/06/01 Vue.js