el-table自适应列宽
1.Vue跨域详解2.Vue 打包后报 Uncaught SyntaxError: Unexpected token ‘<‘3.TypeError: Cannot read property 'upgrade' of undefined4.Vue选日期滚动条自动定位到选定的日期位置5.Vue根据时间戳制作倒计时15分钟6.防抖节流utils7.一些JS过滤方法8.Vue全局公共服务类mixin9.npm install报错node-sass@7.0.1 postinstall: `node scripts/build.js`10.vue一直处在2.9.6版本卸载不了升级不了解决方案11.Vue 全局避免按钮重复点击12.Vue2 去除定时器之常用三种方式及特殊方式13.Vue Element-ui 之 el-table自动滚动
14.el-table自适应列宽
15.vue工程内下载路由16.40% building 31/38 modules 7 active ...es\core-js\modules\es6.object.assign.jsBrowserslist: caniuse-lite is outdated.17.Vue监听系统是否为暗黑模式这里可对内容为文本的列进行自适应列宽
以下为 工具方法
/** * 使用span标签包裹内容,然后计算span的宽度 width: px * @param valArr */ function getTextWidth(str) { let width = 0;
// 创建 span 标签对象 并对该标签 插入 文本属性 及 类名 let html = document.createElement('span'); html.innerText = str; html.className = 'getTextWidth';
// 获取 body 元素 并插入 前面创建的 span 标签 document.querySelector('body').appendChild(html);
// 获取当前 span 标签 的类名的 偏移宽度,这个宽度与页面所显示宽度一致 width = document.querySelector('.getTextWidth').offsetWidth; document.querySelector('.getTextWidth').remove(); return width; } /** * 遍历列的所有内容,获取最宽一列的宽度 * @param arr */ function getMaxLength(arr) { return arr.reduce((acc, item) => { if (item) { let calcLen = getTextWidth(item) if (acc < calcLen) { acc = calcLen } } return acc }, 0) }
完成了工具方法的实现,下面对el-table的数据源进行处理
tableData: { handler(oldVal, newVal) { this.tableData = oldVal const _this = this _this.tableData = _this.tableData.map(function(value) { const arr = oldVal.map(x => x[value.prop]) // 获取每一列的所有数据 arr.push(value.label) // 把每列的表头也加进去算 value.width = getMaxLength(arr) + 20 // 每列内容最大的宽度 + 表格的内间距(依据实际情况而定) return value }) }, deep: true, immediate: true },
页面el-table渲染dom结构
<el-table-column v-for="(item,index) in tableData" :key="Math.random()" :prop="item.prop" :label="item.label" :width="item.width"></el-table-column>
这里要求自定义一个 列表结构 ,可在工具类自定义 也可在 data 定义
tableData: [{ label: '姓名', prop: 'name', width: "60" } ],
本文来自博客园,作者:甲辰哥来帮你算命,转载请注明原文链接:https://www.cnblogs.com/linboomboom/p/16267294.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具
2021-05-13 下载与安装Node.js