vue a-table 实现指定字段相同数据合并行

vue a-table 实现相同数据合并行

实现效果

代码实现

cloums数据格式

javascript 复制代码
const getColumns = function () {
  return [
    {
      title: "分类",
      dataIndex: "checked",
      width: "150px",
      customRender: (text, row, index) => {
        return {
          children:"文字",//合并行的标题
          attrs: {
            // 合并行 含col字段则合并,其他的必须设置为0!!
            rowSpan: row.col ? row.col : 0,
          },
        };
      },
    },
  ];
}

数据源格式

我们这里把相同的checked字段值进行合并

javascript 复制代码
[
  {
      "id": "65d45",
      "checked": "档案管理"
  },
  {
      "id": "65346",
      "checked": "档案管理"
  },
  {
      "id": "6514d",
      "checked": "动态监控"
  },
  {
      "id": "65d83",
      "checked": "动态监控"
  }
]

合并代码

javascript 复制代码
export const dealList = (arr) => {
  const list = arr
    .filter((item) => item.checked)
    .map((item) => {
      return {
        ...item,
        col: 0,
      };
    })
    .sort(function (a, b) {
      return (a.checked + "").localeCompare(b.checked + "");
    });
  // sort进行排序,方便计算
  const colList = [];
  arr.map((o) => {
    const arr = indexcount(list, o.checked);
    colList.push({
      col: arr.length,
      idex: arr[0],
    });
  });
  list.map((o, index) => {
    colList.map((m) => {
      if (index === m.idex) {
        o.col = m.col;
      }
    });
  });
  return list;
};
// 出现次数
function indexcount(arr, item) {
  var arr1 = [];
  for (var i = 0; i < arr.length; i++) {
    if (arr[i].checked == item) {
      arr1.push(i);
    }
  }
  return arr1;
}
相关推荐
vanora11115 分钟前
Vue在线预览excel、word、ppt等格式数据。
前端·javascript·vue.js
溪饱鱼13 分钟前
React源码阅读-fiber核心构建原理
前端·javascript·react.js
xiaogg367834 分钟前
网站首页菜单顶部下拉上下布局以及可关闭标签页实现vue+elementui
javascript·vue.js·elementui
胡gh35 分钟前
JS面向对象程序设计(OOP)与原型机制,到底是如何一步步走向实用的
javascript
有梦想的攻城狮1 小时前
从0开始学vue:pnpm怎么安装
前端·javascript·vue.js
pzpcxy5201 小时前
安装VUE客户端@vue/cli报错警告npm WARN deprecated解决方法 无法将“vue”项识别为 cmdlet、函数
前端·vue.js·npm
疯狂的沙粒1 小时前
uni-app 如何实现选择和上传非图像、视频文件?
前端·javascript·uni-app
Mintopia2 小时前
光影魔术师的秘密:用 JavaScript 打造软阴影的奇幻世界
前端·javascript·计算机图形学
Mintopia2 小时前
Three.js 粒子系统:让代码化身奇幻造梦师
前端·javascript·three.js
mpr0xy2 小时前
React Router 中 navigate 后浏览器返回按钮不起作用的问题记录
javascript·react.js·浏览器·路由