element Plus中 el-table表头宽度自适应,不换行

在工作中,使用el-table表格进行开发后,遇到了小屏幕显示器上显示表头文字会出现换行展示,比较影响美观,因此需要让表头的宽度变为不换行,且由内容自动撑开。

以下是作为工作记录,用于demo演示教程

先贴个需要优化的代码

javascript 复制代码
<template>
    <div style="width: 100%;height: 100%;overflow: hidden;">
        <el-table :data="tableData" >
            <el-table-column prop="date" label="info_Date"/>
            <el-table-column prop="name" label="info_Name"/>
            <el-table-column prop="age" label="info_Age"/>
            <el-table-column prop="gender" label="info_Gender"/>
            <el-table-column prop="type" label="info_Type"/>
            <el-table-column prop="address" label="info_Address" />
        </el-table>
    </div>
</template>

<script lang="ts" setup>
const tableData = [
    {
        date: '05-03',
        name: '张三',
        age:18,
        gender:'男',
        type:'高中生',
        address: 'No. 189, Grove St, Los Angeles',
    },
    {
        date: '05-02',
        name: '李四',
        age:19,
        gender:'女',
        type:'大学生',
        address: 'No. 189, Grove St, Los Angeles',
    }
]
</script>

在页面中的效果是,表头出现了换行的情况

根据官网提示 列标题 Label 区域渲染使用的 Function => render-header,于是就使用这个方法对表头等宽度进行计算

javascript 复制代码
<template>
    <div style="width: 100%;height: 100%;overflow: hidden;">
        <el-table :data="tableData">
            <el-table-column prop="date" label="info_Date"  :render-header="renderHeader"/>
            <el-table-column prop="name" label="info_Name"  :render-header="renderHeader"/>
            <el-table-column prop="age" label="info_Age"  :render-header="renderHeader"/>
            <el-table-column prop="gender" label="info_Gender"  :render-header="renderHeader"/>
            <el-table-column prop="type" label="info_Type"  :render-header="renderHeader"/>
            <el-table-column prop="address" label="info_Address"  :render-header="renderHeader"/>
        </el-table>
    </div>
</template>



const renderHeader = ({ column }) => {
    //创建一个元素用于存放表头信息
    const span = document.createElement('span')
    // 将表头信息渲染到元素上
    span.innerText = column.label
    // 在界面中添加该元素
    document.body.appendChild(span)
    //获取该元素的宽度(包含内外边距等信息)
    const spanWidth = span.getBoundingClientRect().width + 20  //渲染后的 div 内左右 padding 都是 10,所以 +20
    //判断是否小于element的最小宽度,两者取最大值
    column.minWidth = column.minWidth > spanWidth ? column.minWidth : spanWidth
    // 计算完成后,删除该元素
    document.body.removeChild(span)
    return column.label
}

效果已经实现

相关推荐
2601_9583529010 小时前
双麦 DSP 音频模块实战:一文梳理 A-68 在全行业场景的声学解决方案与落地要点
前端·嵌入式硬件·音视频·语音识别·降噪消回音·音频处理模块
智码看视界10 小时前
老梁聊全栈:JavaScript 原型链深入探索对象继承的奥秘
前端·javascript·ecmascript
智码看视界10 小时前
老梁聊全栈系列 JavaScript语言本质:从原型链到异步编程的深度解析
开发语言·javascript·全栈·javascript核心
布朗克16810 小时前
39 Spring Boot Web实战
前端·spring boot·后端·实战
纽格立科技11 小时前
DRM 发射端链路图(上)
前端·人工智能·车载系统·信息与通信·传媒
一 乐11 小时前
幼儿园管理系统|基于springboot + vue幼儿园管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·幼儿园管理系统
云水一下11 小时前
Vue.js从零到精通系列(七):高级特性实战——Teleport、异步组件、自定义指令与TypeScript深度结合
前端·vue.js·typescript
qq43569470111 小时前
Vue05
前端·vue.js
qq_4221525711 小时前
PDF 解密工具怎么选?2026 年文档密码移除方案与注意事项
java·前端·pdf
YHHLAI11 小时前
前端工程化调用 AI 多模态生图模型:Qwen Image Demo 实战
前端·人工智能