春去春会来 發表於 2025-4-10 12:06:00

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

<p>vxe-table修改单元格高度的几种方式,在开发项目时,有时默认的表格高度不能满足需求,这时候就可以调整默认的单元格高度。</p>
<p>查看官网:https://vxetable.cn<br>
gitbub:https://github.com/x-extends/vxe-table<br>
gitee:https://gitee.com/x-extends/vxe-table</p>
<pre><code>npm install vxe-table@4.13.0
</code></pre>
<pre><code class="language-javascript">// ...
import VxeUITable from 'vxe-table'
import 'vxe-table/lib/style.css'
// ...

createApp(App).use(VxeUITable).mount('#app')
// ...
</code></pre>
<h2 id="内置的-size-修改">内置的 size 修改</h2>
<p>可以设置大小尺寸:medium / small / mini</p>
<p><img src="https://img2024.cnblogs.com/blog/3563285/202504/3563285-20250410120507774-640106039.png"></p>
<pre><code class="language-html">&lt;template&gt;
&lt;div&gt;
    &lt;vxe-grid v-bind="gridOptions"&gt;&lt;/vxe-grid&gt;
&lt;/div&gt;
&lt;/template&gt;

&lt;script setup&gt;
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' }
]
})
&lt;/script&gt;
</code></pre>
<h2 id="css-变量修改">css 变量修改</h2>
<p>支持全局或者局部修改</p>
<p><img src="https://img2024.cnblogs.com/blog/3563285/202504/3563285-20250410120529039-1501239797.png"></p>
<pre><code class="language-html">&lt;template&gt;
&lt;div&gt;
    &lt;vxe-radio-group v-model="gridOptions.size"&gt;
      &lt;vxe-radio-button label="" content="默认"&gt;&lt;/vxe-radio-button&gt;
      &lt;vxe-radio-button label="medium" content="中"&gt;&lt;/vxe-radio-button&gt;
      &lt;vxe-radio-button label="small" content="小"&gt;&lt;/vxe-radio-button&gt;
      &lt;vxe-radio-button label="mini" content="迷你"&gt;&lt;/vxe-radio-button&gt;
    &lt;/vxe-radio-group&gt;

    &lt;vxe-grid class="my-table-row-height" v-bind="gridOptions"&gt;&lt;/vxe-grid&gt;
&lt;/div&gt;
&lt;/template&gt;

&lt;script setup&gt;
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' }
]
})

&lt;/script&gt;

&lt;style lang="scss" scoped&gt;
.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;
}
&lt;/style&gt;
</code></pre>
<h2 id="通过-cell-config-配置项修改">通过 cell-config 配置项修改</h2>
<p>配置 cell-config.height</p>
<p><img src="https://img2024.cnblogs.com/blog/3563285/202504/3563285-20250410120544756-1387607027.png"></p>
<pre><code class="language-html">&lt;template&gt;
&lt;div&gt;
    &lt;vxe-grid v-bind="gridOptions"&gt;&lt;/vxe-grid&gt;
&lt;/div&gt;
&lt;/template&gt;

&lt;script setup&gt;
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' }
]
})
&lt;/script&gt;
</code></pre>
<p>https://gitee.com/x-extends/vxe-table</p><br><br>
来源:https://www.cnblogs.com/qaz666/p/18818249
頁: [1]
查看完整版本: vxe-table修改单元格高度的几种方式