vue3 el-table动态表头

在 Vue 3 中使用 Element Plus 的 <el-table> 组件实现动态表头,可以通过绑定 table-columnprop 属性来动态地改变列的名称或者通过计算属性来动态生成列的配置。以下是一些实现动态表头的方法:

方法1:使用 v-for 指令

你可以在 <el-table-column> 上使用 v-for 指令来动态生成列。这种方式适用于列数和列名在运行时可能会改变的情况。

复制代码
<template>
  <el-table :data="tableData" style="width: 100%">
    <el-table-column
      v-for="column in columns"
      :key="column.prop"
      :prop="column.prop"
      :label="column.label"
      :width="column.width">
    </el-table-column>
  </el-table>
</template>
 
<script setup>
import { ref } from 'vue';
 
const columns = ref([
  { prop: 'date', label: '日期', width: 180 },
  { prop: 'name', label: '姓名', width: 180 },
  { prop: 'address', label: '地址' }
]);
 
const tableData = ref([
  { date: '2023-04-01', name: '张三', address: '上海市浦东新区' },
  { date: '2023-04-02', name: '李四', address: '北京市海淀区' }
]);
</script>

方法2:使用计算属性动态生成列配置

如果你需要根据某些条件(如用户选择、API响应等)动态改变列的显示,可以使用计算属性。

复制代码
<template>
  <el-table :data="tableData" style="width: 100%">
    <el-table-column
      v-for="column in computedColumns"
      :key="column.prop"
      :prop="column.prop"
      :label="column.label"
      :width="column.width">
    </el-table-column>
  </el-table>
</template>
 
<script setup>
import { ref, computed } from 'vue';
 
const showAddress = ref(true); // 控制是否显示地址列的开关
const tableData = ref([...]); // 你的数据数组
 
const computedColumns = computed(() => {
  return [
    { prop: 'date', label: '日期', width: 180 },
    { prop: 'name', label: '姓名', width: 180 },
    showAddress.value ? { prop: 'address', label: '地址' } : null // 根据 showAddress 的值决定是否包含地址列
  ].filter(Boolean); // 过滤掉 null 值,即不显示的列
});
</script>

方法3:通过插槽自定义表头内容(更复杂场景)

如果你需要更复杂的表头内容(如合并单元格、自定义渲染等),你可以使用 <el-table>header 插槽。这种方法适用于需要高度自定义表头的情况。

复制代码
<template>
  <el-table :data="tableData" style="width: 100%">
    <el-table-column v-for="column in columns" :key="column.prop" :prop="column.prop">
      <template #header>
        <span>{{ column.label }}</span> <!-- 自定义表头内容 -->
      </template>
    </el-table-column>
  </el-table>
</template>

在这个例子中,你可以在 #header 插槽中添加任何自定义的 HTML 或组件,从而实现复杂的表头布局。例如,你可能需要合并某些单元格或者添加额外的按钮和下拉菜单等。这需要你对 Vue 和 Element Plus 有一定的了解,以及对 HTML 和 CSS 有一定的掌握。

相关推荐
东东5161 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino1 小时前
图片、文件的预览
前端·javascript
2501_920931703 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
AI老李3 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
方也_arkling3 小时前
Element Plus主题色定制
javascript·sass
晓晓莺歌3 小时前
vue3某一个路由切换,导致所有路由页面均变成空白页
前端·vue.js
2601_949809594 小时前
flutter_for_openharmony家庭相册app实战+我的Tab实现
java·javascript·flutter
Up九五小庞4 小时前
开源埋点分析平台 ClkLog 本地部署 + Web JS 埋点测试实战--九五小庞
前端·javascript·开源
摘星编程4 小时前
React Native + OpenHarmony:UniversalLink通用链接
javascript·react native·react.js
qq_177767375 小时前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos