<template>
<el-table
ref="tableRef"
v-loading="loading"
:data="tableData"
border
stripe
:header-cell-style="MyHeaderCellStyle"
:cell-style="MyCellStyle"
show-summary
:summary-method="accountSummaries2"
:height="TableHeight"
>
<el-table-column label="序号" type="index" align="center" fixed />
<el-table-column
label="单位"
prop="branch_name"
align="center"
fixed
sortable
sort-by="branch_no"
:width="flexColumnWidth('单位','branch_name')"
/>
<el-table-column v-for="item in headerData" :key="item.name" :label="item.name" align="center">
<el-table-column
v-for="obj in item.children"
:key="obj.prop"
:label="obj.label"
:prop="obj.prop"
align="center"
sortable
:formatter="handleFormatter"
/>
</el-table-column>
</el-table>
</template>
export default {
methods: {
/**
* 遍历列的所有内容,获取最宽一列的宽度
* @param arr
*/
getMaxLength (arr) {
return arr.reduce((acc, item) => {
if (item) {
const calcLen = this.getTextWidth(item)
if (acc < calcLen) {
acc = calcLen
}
}
return acc
}, 0)
},
/**
* 使用span标签包裹内容,然后计算span的宽度 width: px
* @param valArr
*/
getTextWidth (str) {
let width = 0
const html = document.createElement('span')
html.innerText = str
html.className = 'getTextWidth'
document.querySelector('body').appendChild(html)
width = document.querySelector('.getTextWidth').offsetWidth
document.querySelector('.getTextWidth').remove()
return width
},
/**
* el-table-column 自适应列宽
* @param prop_label: 表名
* @param table_data: 表格数据
*/
flexColumnWidth (label, prop) {
// console.log('label', label)
// console.log('prop', prop)
// 1.获取该列的所有数据
const arr = this.tableData.map(x => x[prop])
arr.push(label) // 把每列的表头也加进去算
// console.log(arr)
// 2.计算每列内容最大的宽度 + 表格的内间距(依据实际情况而定)
return (this.getMaxLength(arr) + 25) + 'px'
}
}
}
原文地址:https://blog.csdn.net/StevenYanghahha/article/details/130581203
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_7871.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。