1、在el-table-column标签上增加 :width="flexWidth(item.value, list, item.label)
2、写flexWidth方法
这个方法既可以横向滚动,也可以自适应宽度,并且左侧固定的列也不会受影响。
完整代码如下
<el-table
:data="list"
border
style="width: 100%"
v-loading="loading"
@sort-change="sortChange"
element-loading-text="拼命加载中"
element-loading-spinner="el-icon-loading"
element-loading-background="rgba(255, 255, 255, 0.6)"
>
<el-table-column :width="flexWidth(item.value, list, item.label)" :fixed="i > fixed ? false : true" :sortable="i > sortable ? true : false" v-for="(item, i) in titleArrs" :prop="item.value" :label="item.label" :key="i">
<template v-slot:header v-if="item.equipment || item.account">
<tooltip-box :show-icon="false" :text="item.label">
<div class="ar-style">
<template v-if="json.dimension === 1">
<span class="text-theme text-bold">{{ item.label }} = </span>
<span>{{ item.equipment }}</span>
</template>
<template v-else-if="json.dimension === 2">
<span class="text-theme text-bold">{{ item.label }} = </span>
<span>{{ item.account }}</span>
</template>
</div>
</tooltip-box>
</template>
</el-table-column>
<div slot="empty">
<el-empty description="暂无数据"></el-empty>
</div>
</el-table>
/**
* flexWidth
* @param prop 每列的prop 可传''
* @param tableData 表格数据
* @param title 标题长内容短的,传标题 可不传
* @param num 列中有标签等加的富余量
* @returns 列的宽度
* 注:prop,title有一个必传
*/
flexWidth(prop, tableData, title, num = 0) {
if (tableData.length === 0 ) {//表格没数据不做处理
return;
}
let flexWidth = 0;//初始化表格列宽
let columnContent = '';//占位最宽的内容
let canvas = document.createElement("canvas");
let context = canvas.getContext("2d");
context.font = "14px Microsoft YaHei";
if ((prop === '') && title) {//标题长内容少的,取标题的值,
columnContent = title
} else {// 获取该列中占位最宽的内容
let index = 0;
for (let i = 0; i < tableData.length; i++) {
const now_temp = tableData[i][prop] + '';
const max_temp = tableData[index][prop] + '';
const now_temp_w = context.measureText(now_temp).width
const max_temp_w = context.measureText(max_temp).width
if (now_temp_w > max_temp_w) {
index = i;
}
}
columnContent = tableData[index][prop]
//比较占位最宽的值跟标题、标题为空的留出四个位置
const column_w = context.measureText(columnContent).width
const title_w = context.measureText(title).width
if (column_w < title_w) {
columnContent = title || '留四个字'
}
}
// 计算最宽内容的列宽
let width = context.measureText(columnContent);
flexWidth = width.width + 60 + num
return flexWidth + 'px';
},