[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 })
相关推荐
爱勇宝4 分钟前
深扒 Anthropic 1680 位工程师简历:应届生几乎没机会,AI 公司最缺的不是博士
前端·后端·程序员
kyriewen34 分钟前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程
user20585561518133 小时前
Windows 项目安装时报 `node-sass` 错误,如何快速处理
前端
LiaCode3 小时前
Redis 在生产项目的使用
前端·后端
LiaCode3 小时前
一天学完 redis 的爽翻版核心知识总结
前端·后端
大刚测试开发实战3 小时前
如何内网穿透访问本地私有化部署的TestHub
前端·后端·github
风骏时光牛马3 小时前
# Ruby基于Rails框架实现多角色权限管理与数据分页查询完整实战代码案例
前端
weedsfly3 小时前
迭代器、生成器与异步迭代——让数据“按需流动”的艺术
前端·javascript
xiaodaoluanzha3 小时前
迄今為止,最簡單的編程語言 Nolang
前端·后端
Csvn3 小时前
Fetch 请求竞态终结者:AbortController 不只是用来"取消"的
前端