修改 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...

相关推荐
军军君0128 分钟前
Three.js基础功能学习十五:智能黑板实现实例二
开发语言·前端·javascript·vue.js·3d·threejs·三维
IT枫斗者36 分钟前
构建具有执行功能的 AI Agent:基于工作记忆的任务规划与元认知监控架构
android·前端·vue.js·spring boot·后端·架构
hotlinhao37 分钟前
Nginx rewrite last 与 redirect 的区别——Vue history 模式短链接踩坑记录
前端·vue.js·nginx
weixin_461769401 小时前
npm create vue@latest 错误
前端·vue.js·npm
写不来代码的草莓熊1 小时前
el-date-picker ,自定义输入数字自动转换显示yyyy-mm-dd HH:mm:ss格式
前端·javascript·vue.js
风之舞_yjf2 小时前
Vue基础(31)_插件(plugins)、scoped样式
前端·vue.js
M ? A2 小时前
Vue3+TS实战避坑指南
前端·vue.js·经验分享
Cobyte2 小时前
4.响应式系统基础:从发布订阅模式的角度理解 Vue3 的数据响应式原理
前端·javascript·vue.js
禅思院3 小时前
使用 VueUse 构建一个支持暂停/重置的 CountUp 组件
前端·vue.js·架构