修改 vxe-table 单元格高度的几种方式,在开发项目时,有时默认的表格高度不能满足需求,这时候就可以调整默认的单元格高度。
查看官网:vxetable.cn
gitbub:github.com/x-extends/v...
gitee:gitee.com/x-extends/v...
css
npm install [email protected]
javascript
// ...
import VxeUITable from 'vxe-table'
import 'vxe-table/lib/style.css'
// ...
createApp(App).use(VxeUITable).mount('#app')
// ...
内置的 size 修改
可以设置大小尺寸:medium / small / mini

html
<template>
<div>
<vxe-grid v-bind="gridOptions"></vxe-grid>
</div>
</template>
<script setup>
import { reactive } from 'vue'
const gridOptions = reactive({
border: true,
size: 'small',
columns: [
{ type: 'seq', width: 70 },
{ type: 'radio', width: 60 },
{ type: 'checkbox', width: 60 },
{ field: 'name', title: 'Name' },
{ field: 'age', title: 'Age', sortable: true },
{
field: 'sex',
title: 'Sex',
filters: [
{ value: '0', label: '女' },
{ value: '1', label: '男' }
]
},
{
field: 'sex2',
title: 'Sex2',
sortable: true,
filterMultiple: false,
filters: [
{ value: '0', label: '女' },
{ value: '1', label: '男' }
]
},
{ field: 'address', title: 'Address', showOverflow: true }
],
data: [
{ id: 10001, name: 'Test1', role: 'Develop', sex: 'Man', age: 28, address: 'test abc' },
{ id: 10002, name: 'Test2', role: 'Test', sex: 'Women', age: 22, address: 'Guangzhou' }
]
})
</script>
css 变量修改
支持全局或者局部修改

html
<template>
<div>
<vxe-radio-group v-model="gridOptions.size">
<vxe-radio-button label="" content="默认"></vxe-radio-button>
<vxe-radio-button label="medium" content="中"></vxe-radio-button>
<vxe-radio-button label="small" content="小"></vxe-radio-button>
<vxe-radio-button label="mini" content="迷你"></vxe-radio-button>
</vxe-radio-group>
<vxe-grid class="my-table-row-height" v-bind="gridOptions"></vxe-grid>
</div>
</template>
<script setup>
import { reactive } from 'vue'
const gridOptions = reactive({
border: true,
showFooter: true,
size: '',
columns: [
{ field: 'seq', type: 'seq', width: 70 },
{ field: 'name', title: 'Name' },
{ field: 'sex', title: 'Sex' },
{ field: 'age', title: 'Age' }
],
data: [
{ id: 10001, name: 'Test1', role: 'Develop', sex: 'Man', age: 28, address: 'test abc' },
{ id: 10002, name: 'Test2', role: 'Test', sex: 'Women', age: 22, address: 'Guangzhou' },
{ id: 10003, name: 'Test3', role: 'PM', sex: 'Man', age: 32, address: 'Shanghai' },
{ id: 10004, name: 'Test4', role: 'Designer', sex: 'Women', age: 24, address: 'Shanghai' }
],
footerData: [
{ seq: '合计', name: '777', sex: '333', age: '111' }
]
})
</script>
<style lang="scss" scoped>
.my-table-row-height {
--vxe-ui-table-row-height-default: 80px;
--vxe-ui-table-row-height-medium: 60px;
--vxe-ui-table-row-height-small: 40px;
--vxe-ui-table-row-height-mini: 20px;
}
</style>
通过 cell-config 配置项修改
配置 cell-config.height

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,
cellConfig: {
height: 80
},
columns: [
{ field: 'seq', type: 'seq', width: 70 },
{ field: 'name', title: 'Name' },
{ field: 'sex', title: 'Sex' },
{ field: 'age', title: 'Age' },
{ field: 'address', title: 'Address', width: 200 }
],
data: [
{ id: 10001, name: 'Test1', role: 'Develop', sex: 'Man', age: 28, address: 'test abc' },
{ id: 10002, name: 'Test2', role: 'Test', sex: 'Women', age: 22, address: 'Guangzhou Guangzhou Guangzhou Guangzhou Guangzhou' },
{ id: 10003, name: 'Test3', role: 'PM', sex: 'Man', age: 32, address: 'Shanghai Shanghai Shanghai Shanghai' },
{ id: 10004, name: 'Test4', role: 'Designer', sex: 'Women', age: 24, address: 'Shanghai' }
],
footerData: [
{ seq: '合计', name: '777', sex: '333', age: '111' }
]
})
</script>