[vxe-table] 合并单元格

通过设置 merge-cells={ row: 第几行开始, col: 第几列开始, rowspan: 合并多少行, colspan: 合并多少列 } 配置合并规则

官方api-合并单元格

html 复制代码
<vxe-grid v-bind="gridOptions"></vxe-grid>
javascript 复制代码
/**
 * 生成合并单元格配置的函数
 * @param {Array} data - 表格数据数组
 * @param {string} field - 要合并的字段名
 * @param {number} columnIndex - 字段对应的列索引
 * @returns {Array} 合并单元格配置数组
 */
const generateMergeCells = (data, field, columnIndex) => {
  // 数据为空时返回空数组
  if (!data || data.length === 0) return []
  
  const mergeCells = []
  let currentValue = data[0][field] // 当前比较的值
  let startRow = 0 // 开始合并的行索引
  let count = 1 // 连续相同值的行数
  
  // 遍历数据,找出连续相同值的行
  for (let i = 1; i < data.length; i++) {
    if (data[i][field] === currentValue) {
      // 当前值与上一个值相同,增加计数
      count++
    } else {
      // 当前值与上一个值不同
      if (count > 1) {
        // 如果有连续相同值,添加合并配置
        mergeCells.push({
          row: startRow, // 开始行
          col: columnIndex, // 列索引
          rowspan: count, // 合并行数
          colspan: 1 // 合并列数
        })
      }
      // 更新当前值和起始行
      currentValue = data[i][field]
      startRow = i
      count = 1
    }
  }
  
  // 处理最后一组连续相同值
  if (count > 1) {
    mergeCells.push({
      row: startRow,
      col: columnIndex,
      rowspan: count,
      colspan: 1
    })
  }
  
  return mergeCells
}

/**
 * 表格数据
 * 包含员工的基本信息,用于演示合并单元格功能
 */
const tableData = reactive([
  { id: 1, name: '张三', department: '技术部', position: '前端工程师', salary: 15000 },
  { id: 2, name: '李四', department: '技术部', position: '后端工程师', salary: 16000 },
  { id: 3, name: '王五', department: '技术部', position: '测试工程师', salary: 14000 },
  { id: 4, name: '赵六', department: '市场部', position: '市场专员', salary: 12000 },
  { id: 5, name: '钱七', department: '市场部', position: '市场经理', salary: 18000 },
  { id: 6, name: '孙八', department: '财务部', position: '会计', salary: 13000 },
  { id: 7, name: '孙八1', department: '财务部', position: '会计', salary: 13000 },
])

/**
 * 计算合并单元格配置
 * 基于tableData中的department字段自动生成合并配置
 */
const mergeCells = computed(() => {
  return generateMergeCells(tableData, 'department', 2)
})

/**
 * 表格配置选项
 * 包含表格的列定义、数据和合并单元格配置
 */
const gridOptions = reactive({
  border: true, // 显示表格边框
  columns: [
    { type: 'seq', width: 70, title: '序号' }, // 序号列
    { field: 'name', title: '姓名', width: 120, slots: { header: 'header_name' } }, // 姓名字段,支持表头编辑
    { field: 'department', title: '部门', width: 150, slots: { header: 'header_department' } }, // 部门字段,支持表头编辑和单元格合并
    { field: 'position', title: '职位', width: 150, slots: { header: 'header_position' } }, // 职位字段,支持表头编辑
    { field: 'salary', title: '薪资', width: 120, slots: { header: 'header_salary' } }, // 薪资字段,支持表头编辑
  ],
  data: tableData, // 表格数据
  // 合并单元格配置 - 根据数据自动生成
  mergeCells: mergeCells.value,
})

/**
 * 监听数据变化,更新合并单元格配置
 * 使用深度监听确保数据嵌套变化时也能触发更新
 * 通过创建数组副本作为监听源,确保数组变化能被检测到
 */
watch(() => [...tableData], () => {
  gridOptions.mergeCells = generateMergeCells(tableData, 'department', 2)
}, { deep: true })
相关推荐
NiceCloud喜云6 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
wordbaby6 小时前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
丷丩6 小时前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
Front思7 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫9 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。10 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星10 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒10 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩11 小时前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi11 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具