关于elementUi表格合并行数据并展示序号

 更新时间:2023年04月25日 08:40:35   作者:小太阳...  
这篇文章主要介绍了关于elementUi表格合并行数据并展示序号,通过给table传入span-method方法可以实现合并行或列,方法的参数是一个对象,感兴趣的朋友可以学习一下

效果如下:属于同一个厂商的数据要合并成一行

在这里插入图片描述

element官网对于合并行和列是这样说的:

通过给table传入span-method方法可以实现合并行或列,方法的参数是一个对象,里面包含当前行row、当前列column、当前行号rowIndex、当前列号columnIndex四个属性。该函数可以返回一个包含两个元素的数组,第一个元素代表rowspan,第二个元素代表colspan。 也可以返回一个键名为rowspancolspan的对象。

实现合并行思路:需要一个数据来记录需要合并的行数据(数字几就代表合并几行,比如 [1, 2, 0, 1]就是第一行第四行不变,第二三行合并成一行),还要有一个变量来记录数组下标。 注意:后台返回的数据一定要有能区分唯一性的数据,来判断前后两条数据是否一样。 主要代码如下:

    <base-table
      :table-data="tableData"
      :table-title="tableTitle"
      :span-method="objectSpanMethod"
      max-height="600px"
      v-bind="$attrs"
    >
      <template slot-scope="scope" slot="serialNo">
        {{ scope.row.serialNo }}
      </template>
      ....
    </base-table>
const tableTitle = [
  {
    key: 'serialNo',
    title: '序号',
    align: 'center',
    width: '100',
    scopedSlots: { customRender: 'serialNo' }
  },
  {
    key: 'unionList',
    title: '厂商名称(编号)',
    align: 'center',
    width: '300px',
    scopedSlots: { customRender: 'unionList' }
  },
  {
    key: 'unionName',
    title: 'MQ厂商',
    tooltip: true,
    align: 'center'
  },
]
export default {
  data() {
    return {
      tableTitle,
      tableData: [],
      spanArr: [], // 存合并行数据的数组
      pos: 0,// 合并行数据数组下标
      rowIndex: 1 // 序号
    }
  },

  methods: {
    getTableData() {
      this.tableData = [
        {
          accessId: '1',
          id: 1,
          mqPassword: '1011',
          privateKey: '1011',
          publicKey: '1011',
          unionList: "[{\"union_name\":\"乐乐\",\"union_id\":\"200160\"}]",
          unionName: '1011'
        },
        {
          accessId: '2',
          id: 2,
          mqPassword: '1012',
          privateKey: '1012',
          publicKey: '1012',
          unionList: "[{\"union_name\":\"小太阳\",\"union_id\":\"200734\"},{\"union_name\":\"包子\",\"union_id\":\"200737\"}]",
          unionName: '1012'
        },
        {
          accessId: '3',
          id: 3,
          mqPassword: '1013',
          privateKey: '1013',
          publicKey: '1013',
          unionList: "[{\"union_name\":\"小太阳\",\"union_id\":\"200734\"},{\"union_name\":\"包子\",\"union_id\":\"200737\"}]",
          unionName: '1013'
        },
        {
          accessId: '4',
          id: 4,
          mqPassword: '1014',
          privateKey: '1014',
          publicKey: '1014',
          unionList: "[{\"union_name\":\"测试\",\"union_id\":\"200160\"}]",
          unionName: '1014'
        },
      ]
      this.getSpanArr(this.tableData) // 获取合并单元格数据和序号
    },
    getSpanArr(data) {
    // 重新查询后,要清空行数据数组、序号重置为1
      this.spanArr = []
      this.rowIndex = 1
      // 遍历数据,判断前后两条数据是否相同
      for (let i = 0; i < data.length; i++) {
        data[i].unionList = JSON.parse(data[i].unionList)
        data[i].unionArr = data[i].unionList.map(i => i.union_id).join(',')
        if (i === 0) {
          this.spanArr.push(1)
          this.pos = 0
          data[i].serialNo = this.rowIndex
          this.rowIndex++
        } else {
          // 判断当前元素与上一元素是否相同
          if (data[i].unionArr === data[i - 1].unionArr) {
            this.spanArr[this.pos] += 1
            this.spanArr.push(0)
          } else {
            this.spanArr.push(1)
            this.pos = i
            data[i].serialNo = this.rowIndex
            this.rowIndex ++
          }
        }
      }
    },
    objectSpanMethod({ row, column, rowIndex, columnIndex }) {
      // 合并操作和厂商名称
      if (columnIndex === 0 || columnIndex === 1 || columnIndex === 2) {
        const _row = this.spanArr[rowIndex]
        const _col = _row > 0 ? 1 : 0
        // rowspan和colspan都为0,则表示这一行不显示,[x, 1]则表示合并了多少行
        return {
          rowspan: _row,
          colspan: _col
        }
      }
    },
  }
}

到此这篇关于关于elementUi表格合并行数据并展示序号的文章就介绍到这了,更多相关elementUi表格合并内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 解决Vue3报错:Property “xxx“ was accessed during render but is not defined on instance.

    解决Vue3报错:Property “xxx“ was accessed during render but

    这篇文章主要给大家介绍了关于解决Vue3报错:Property “xxx“ was accessed during render but is not defined on instance.的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-01-01
  • 深入了解Vue中Vuex的用法

    深入了解Vue中Vuex的用法

    Vuex的官方解释是一个专为vue.js应用程序开发的状态管理模式,这篇文章主要为大家介绍了Vuex的具体用法,希望对大家深入了解Vuex有一定的帮助
    2023-06-06
  • Vue局部组件数据共享Vue.observable()的使用

    Vue局部组件数据共享Vue.observable()的使用

    随着组件的细化,就会遇到多组件状态共享的情况,今天我们介绍的是 vue.js 2.6 新增加的 Observable API ,通过使用这个 api 我们可以应对一些简单的跨组件数据状态共享的情况,感兴趣的可以了解一下
    2021-06-06
  • Vue 3开发中VueUse强大Hooks库

    Vue 3开发中VueUse强大Hooks库

    VueUse提供了一个丰富且强大的Hooks库,可以帮助开发者快速实现各种功能,提高开发效率,本文来详细的介绍一下,需要的朋友们下面随着小编来一起学习学习吧
    2024-08-08
  • vue bus全局事件中心简单Demo详解

    vue bus全局事件中心简单Demo详解

    ue-bus 提供了一个全局事件中心,并将其注入每一个组件,你可以像使用内置事件流一样方便的使用全局事件。这篇文章给大家介绍了vue bus全局事件中心简单Demo,需要的朋友参考下吧
    2018-02-02
  • vue-cli单页应用改成多页应用配置详解

    vue-cli单页应用改成多页应用配置详解

    本篇文章主要介绍了vue-cli单页应用改成多页应用配置详解,具有一定的参考价值,有兴趣的可以了解一下
    2017-07-07
  • vue附件下载无法打开的问题及解决

    vue附件下载无法打开的问题及解决

    这篇文章主要介绍了vue附件下载无法打开的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • koa2+vue实现登陆及登录状态判断

    koa2+vue实现登陆及登录状态判断

    这篇文章主要介绍了koa2+vue实现登陆及登录状态判断,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2019-08-08
  • Vue input控件通过value绑定动态属性及修饰符的方法

    Vue input控件通过value绑定动态属性及修饰符的方法

    这篇文章主要介绍了 Vue input控件通过value绑定动态属性及修饰符的方法,需要的朋友可以参考下
    2017-05-05
  • vue项目中路由跳转页面不变问题及解决

    vue项目中路由跳转页面不变问题及解决

    这篇文章主要介绍了vue项目中路由跳转页面不变问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08

最新评论