view deign 和 vue2 合并单元格的方法

1.vue版本和view design 版本

javascript 复制代码
{
   "vue": "^2.6.11",
   "view-design": "^4.7.0",
}

2.Data中定义数据

复制代码
spanArr: [], // 某一列下需要合并的行数
pos: 0// 索引

// 注意点: 在获取列表前,需要重置 this.spanArr = []

注意点2: 获取列表的请求失败,页需要重置数据(就是列表数据是接口返回的对象中的一个字段,这个列表的标题和数据都是后端返回的,同时返回了其他字段,在请求前你需要重置所有数据,同时重置)

3.方法

javascript 复制代码
getSpanArr(data) {
 data.forEach((item, index) => {
  // 如果是第一个数据,就将列表spanArr添加一个1,表示暂时只有一个名字相同的、且将索引pos赋值为0
    if (index === 0) {
      this.spanArr.push(1)
      this.pos = 0
    } else {
      // 判断当前元素与上一个元素是否相同(这里我们拿要合并的日期date为例)
      if (item.time === data[index - 1].time) {
        // 如果相同就将索引为 pos 的值加一
        this.spanArr[this.pos] += 1
        // 且将数组添加 0
        this.spanArr.push(0)
      } else {
        // 如果元素不同了,就可以通过索引为 pos 的值知道应该需要合并的行数
        // 同时,我们再次添加一个值1,表示重新开始判断某个字段的重复次数
        this.spanArr.push(1)
        // 同时 索引加一
        this.pos = index
      }
    }
  })
},
// 合并单元格的
handleSpan ({ rowIndex, columnIndex }) {
  if (columnIndex === 0) {
    const rowspan = this.spanArr[rowIndex]
    return {
      // 将需要合并的行数赋值给rowspan
      rowspan: rowspan,
      // colspan有两种情况要不是0不显示,要不是1显示,根据rowspan( _row)来确定;
      colspan: rowspan > 0 ? 1 : 0
    }
  }
},
相关推荐
@AfeiyuO7 小时前
封装ElementPlusIcons图标和系统应用内置图片为应用图标
vue
JELEE.8 小时前
Vue3复习笔记
vue.js·笔记·vue
by__csdn9 小时前
第二章 (.NET Core环境搭建)第二节( Visual Studio Code)
ide·vscode·c#·vue·asp.net·.net·.netcore
是梦终空10 小时前
JAVA毕业设计253—基于Java+Springboot+vue3+协同过滤推荐算法的传统服饰文化平台(源代码+数据库+任务书+12000字论文)
java·spring boot·vue·毕业设计·课程设计·协同过滤推荐算法·传统服饰文化平台
水宁成冰1 天前
前端静态网站Lighthouse评分优化,vue3项目
前端·vue
前端无涯1 天前
TypeScript 完整学习指南:从基础到工程化实践
typescript·vue·react
邂逅星河浪漫1 天前
【Dify-Chatflow】简历优化助手实现+前后端分离式系统集成+Docker容器化部署)
java·docker·vue·springboot·dify·apifox
by__csdn1 天前
Vue3 大文件分片上传完整指南:图片/视频附件高效传输方案
前端·javascript·vue.js·typescript·vue·css3·html5
gzmyh1 天前
thinkphp8+vue3整合的工作流实战demo
vue·php·workflow·工作流
离别又见离别2 天前
vue使用js渲染组件案例(公用打印组件动态渲染)及静默打印实现
前端·javascript·vue