vue vxe-table 自适应列宽,根据内容自适应宽度的2种使用方式

vue vxe-table 自适应列宽,根据内容自适应宽度的2种使用方式

查看官网:https://vxetable.cn

第一种,整列根据内容自适应宽度

整列根据内容自适应宽度,包括表头、表体、表尾同时自定义宽度,适用需要完整显示的场景

html 复制代码
<template>
  <div>
    <vxe-grid v-bind="gridOptions"></vxe-grid>
  </div>
</template>

<script setup>
import { reactive } from 'vue'

const gridOptions = reactive({
  border: true,
  showFooter: true,
  columns: [
    { type: 'seq', width: '80' },
    { field: 'name', title: 'Name', width: 300 },
    { field: 'age', title: 'Age', width: 'auto' },
    { field: 'sex', title: '头部宽度 头部宽度 头部', width: 'auto' },
    { field: 'address', title: 'Address', width: 'auto' }
  ],
  data: [
    { id: 10001, name: 'Test1', role: 'Develop Develop Develop ', sex: 'Man', age: 28, address: '内容宽度' },
    { id: 10002, name: 'Test2', role: 'Test Test Test Test Test Test Test', sex: 'Women', age: 22, address: '内容宽度 内容宽度 内容宽度 内容宽度 内容宽度 内容宽度' },
    { id: 10003, name: 'Test3', role: 'PM', sex: 'Man', age: 32, address: '内容宽度 内容宽度 内容宽度 内容' }
  ],
  footerData: [
    { age: '9999999' }
  ]
})
</script>

第二种,仅表体单元格根据内容自适应宽度

仅表体单元格根据内容自适应宽度,表头和表尾不根据内容自适应宽度,适用内容不宽的字段就非常合适了

通过 columnConfig.autoOptions 来配置

html 复制代码
<template>
  <div>
    <vxe-grid v-bind="gridOptions"></vxe-grid>
  </div>
</template>

<script setup>
import { reactive } from 'vue'

const gridOptions = reactive({
  border: true,
  showFooter: true,
  columnConfig: {
    autoOptions: {
      isCalcHeader: false,
      isCalcBody: true,
      isCalcFooter: false
    }
  },
  columns: [
    { type: 'seq', width: '80' },
    { field: 'name', title: 'Name', width: 300 },
    { field: 'age', title: 'Age', width: 'auto' },
    { field: 'sex', title: '头部宽度 头部宽度 头部', width: 'auto' },
    { field: 'address', title: 'Address', width: 'auto' }
  ],
  data: [
    { id: 10001, name: 'Test1', role: 'Develop Develop Develop ', sex: 'Man', age: 28, address: '内容宽度' },
    { id: 10002, name: 'Test2', role: 'Test Test Test Test Test Test Test', sex: 'Women', age: 22, address: '内容宽度 内容宽度 内容宽度 内容宽度 内容宽度 内容宽度' },
    { id: 10003, name: 'Test3', role: 'PM', sex: 'Man', age: 32, address: '内容宽度 内容宽度 内容宽度 内容' }
  ],
  footerData: [
    { age: '9999999' }
  ]
})
</script>

https://vxetable.cn

相关推荐
OpenTiny社区20 分钟前
2025OpenTiny星光ShowTime!年度贡献者征集启动!
前端·vue.js·低代码
狗哥哥32 分钟前
从零到一:打造企业级 Vue 3 高性能表格组件的设计哲学与实践
前端·vue.js·架构
计算机毕设VX:Fegn089537 分钟前
计算机毕业设计|基于springboot + vue图书借阅管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
褪色的笔记簿1 小时前
在 Vue 项目里管理弹窗组件:用 ref 还是用 props?
前端·vue.js
一只小阿乐1 小时前
前端vue3 web端中实现拖拽功能实现列表排序
前端·vue.js·elementui·vue3·前端拖拽
AAA阿giao2 小时前
从“操纵绳子“到“指挥木偶“:Vue3 Composition API 如何彻底改变前端开发范式
开发语言·前端·javascript·vue.js·前端框架·vue3·compositionapi
专注前端30年2 小时前
在日常开发项目中Vue与React应该如何选择?
前端·vue.js·react.js
进击的野人2 小时前
Vue 组件与原型链:VueComponent 与 Vue 的关系解析
前端·vue.js·面试
馬致远2 小时前
Vue todoList案例 优化之本地存储
前端·javascript·vue.js
3秒一个大3 小时前
现代前端开发框架的工程化实践:基于 Vite 与 Vue3
vue.js