修改 vxe-table 单元格高度的几种方式

修改 vxe-table 单元格高度的几种方式,在开发项目时,有时默认的表格高度不能满足需求,这时候就可以调整默认的单元格高度。

查看官网:vxetable.cn

gitbub:github.com/x-extends/v...

gitee:gitee.com/x-extends/v...

css 复制代码
npm install vxe-table@4.13.0
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>

gitee.com/x-extends/v...

相关推荐
Hexene...2 小时前
【前端Vue】如何实现echarts图表根据父元素宽度自适应大小
前端·vue.js·echarts
初遇你时动了情2 小时前
腾讯地图 vue3 使用 封装 地图组件
javascript·vue.js·腾讯地图
华子w9089258593 小时前
基于 SpringBoot+VueJS 的农产品研究报告管理系统设计与实现
vue.js·spring boot·后端
前端小趴菜055 小时前
React-forwardRef-useImperativeHandle
前端·vue.js·react.js
P7Dreamer5 小时前
Vue 3 + Element Plus 实现可定制的动态表格列配置组件
前端·vue.js
I'm写代码5 小时前
el-tree树形结构笔记
javascript·vue.js·笔记
斯~内克6 小时前
基于Vue.js和PDF-Lib的条形码生成与批量打印方案
前端·vue.js·pdf
sunbyte7 小时前
50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | ContentPlaceholder(背景占位)
前端·javascript·css·vue.js·tailwindcss
markyankee1017 小时前
Vue 计算属性和侦听器详解
vue.js
盏茶作酒298 小时前
打造自己的组件库(一)宏函数解析
前端·vue.js