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

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

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

相关推荐
BillKu43 分钟前
遵守 Vue3 的单向数据流原则:父组件传递对象 + 子组件修改对象属性,安全地实现父子组件之间复杂对象的双向绑定示例代码及讲解
javascript·vue.js·elementui
Nuyoah.2 小时前
《vue3学习手记3》
前端·javascript·vue.js·学习·前端框架
初遇你时动了情2 小时前
vue3 uniapp vite 配置之定义指令
javascript·vue.js·uni-app
BillKu2 小时前
reactive 解构赋值给 ref
前端·javascript·vue.js
鑫不想说话1064763 小时前
ts+vue3出乎意料的推导报错
vue.js·typescript
dasseinzumtode3 小时前
在 Vue 3 中实现右键菜单功能
前端·vue.js
工业互联网专业4 小时前
基于springboot+vue的数码产品抢购系统
java·vue.js·spring boot·毕业设计·源码·课程设计·数码产品抢购系统
Data_Adventure4 小时前
使用CLINE快速生成一个3D展厅
vue.js·three.js·cline
周星星日记4 小时前
10.vue3中组件实现原理(上)
前端·vue.js·面试
Mikey_n5 小时前
Vue + Spring Boot 整合全解析
前端·vue.js·spring boot