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

该文章已生成可运行项目,

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

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

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

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

在这里插入图片描述

<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 来配置
在这里插入图片描述

<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

本文章已经生成可运行项目
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值