欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Element中el-table動(dòng)態(tài)合并單元格(span-method方法)

 更新時(shí)間:2023年05月30日 11:14:28   作者:小星星__  
本文主要介紹了Element中el-table動(dòng)態(tài)合并單元格(span-method方法),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

合并單元格

記錄一下工作時(shí)遇到的 el-table 合并單元格的需求,超詳細(xì)??

el-table官方提供了合并單元格的方法與返回格式 如下:

根據(jù)敘述有了如下思路:
因?yàn)楹蠖朔祷氐臄?shù)據(jù)非統(tǒng)一, 可能不是按照類別排好的??, 所以官網(wǎng)的例子滿足不了所有的需求所以我們通過遍歷table的數(shù)據(jù)比較前后兩個(gè)元素是否相等, 來構(gòu)造一個(gè)spanArr用來存放rowspan, 最后通過rowspan的值來判斷colspan的值??.

案例如下, 這是我需要處理的一個(gè)表格:
需要根據(jù)數(shù)據(jù)動(dòng)態(tài)的合并

對(duì)應(yīng)的配置數(shù)組為

處理數(shù)據(jù)

因?yàn)楂@取的數(shù)據(jù)的非統(tǒng)一性, 我們首先要將數(shù)據(jù)根據(jù)我們想要合并的字段進(jìn)行排序分組, 這里我實(shí)現(xiàn)了一個(gè)簡單的方法來處理數(shù)據(jù):

// data 為 表格數(shù)據(jù) , params 為需要合并的字段
groupBy (data, params) {
    const groups = {};
    data.forEach(v => {
    	// 獲取data中的傳入的params屬性對(duì)應(yīng)的屬性值
        const group = JSON.stringify(v[params]);
        // 把group作為groups的key,初始化value,循環(huán)時(shí)找到相同的v[params]時(shí)不變
        groups[group] = groups[group] || [];
        // 將對(duì)應(yīng)找到的值作為value放入數(shù)組中
        groups[group].push(v);
    })
    // 返回處理好的二維數(shù)組
    return Object.values(groups);
},

此時(shí)打印一下我們的數(shù)據(jù)console.log(this.groupBy(this.tableListData.items, 'FirstIndex'))

如圖, 我們已經(jīng)將數(shù)據(jù)分好組并合并在一個(gè)數(shù)組中啦, FirstIndex相同的在一個(gè)數(shù)組

構(gòu)造控制合并的數(shù)組spanArr

這里實(shí)現(xiàn)了一個(gè)方法, 用來構(gòu)造一個(gè)spanArr數(shù)組賦予rowspan,即控制行合并

  • 接收重構(gòu)數(shù)組 let arr = []
  • 設(shè)置索引 let pos = 0
  • 控制合并的數(shù)組 this.spanArr = []

先將groupby()處理好的數(shù)據(jù)再次用arr進(jìn)行處理:連接所有數(shù)組成員為一個(gè)新數(shù)組
this.groupBy(this.tableListData.items, 'FirstIndex').map(v => (arr = arr.concat(v)))

現(xiàn)在處理好了數(shù)據(jù),需要賦予原數(shù)據(jù)了:this.tableListData.items = arr

但是因?yàn)槲沂菍懺?code>getSpanArr(data, params)方法中的,已經(jīng)通過形參data將 this.tableListData.items傳入了這里,如果想方便封裝調(diào)用的話,不用每次使用都需要再次寫入 this.tableListData.items = arr
于是想到一個(gè)辦法,js數(shù)組的shift()和push()是直接修改數(shù)組所占內(nèi)存的方法。
所以有:

arr.map(res => {
    // 每次遍歷都刪除data && this.tableListData.items的第一個(gè)元素
    data.shift()
    // 每次遍歷都將arr數(shù)組元素對(duì)應(yīng)push進(jìn) data && this.tableListData.items
    data.push(res)
})

還需要定義一個(gè)redata存放arr要合并字段的value
const redata = arr.map(v => v[params])

reduce處理spanArr數(shù)組

使用reduce方法比較redata前后兩個(gè)元素是否相等,相等的話spanArr中對(duì)應(yīng)索引的元素的值+1,并且在其后增加一個(gè)0占位(防止合并過后表格數(shù)據(jù)錯(cuò)位),否則的話增加一個(gè)1占位,并記錄當(dāng)前索引,往復(fù)循環(huán),構(gòu)造一個(gè)給 rowspan 取值判斷合并的數(shù)組:

  const redata = arr.map(v => v[params])
  redata.reduce((old, cur, i) => {
    // old 上一個(gè)元素  cur 當(dāng)前元素  i 索引
    if (i === 0) {
      // 第一次判斷先增加一個(gè) 1 占位 ,索引為0 
      this.spanArr.push(1)
      pos = 0
    } else {
      if (cur === old) {
        this.spanArr[pos] += 1
        this.spanArr.push(0)
      } else {
        this.spanArr.push(1)
        pos = i
      }
    }
    return cur
  }, {})

看一下現(xiàn)在的數(shù)據(jù)spanArr, 這里傳的參數(shù)為SecondIndex, 即表格的第二列

數(shù)組中大于0的數(shù)字就是我們數(shù)據(jù)中要合并的這組數(shù)據(jù)的數(shù)量, 同時(shí)也是這組數(shù)據(jù)需要合并的列數(shù),而0就是代表這列不合并, 依次遍歷,實(shí)現(xiàn)合并所選字段這一列的最終目的 如圖理解:

返回最終結(jié)果

最后一步啦??根據(jù)官方給的方法把我們處理好的spanArr傳給rowspan即可

spanMethod({ row, column, rowIndex, columnIndex }) {
  // 第一列
  if (columnIndex === 0) {
    const _row = this.spanArr[rowIndex];
    const _col = _row > 0 ? 1 : 0;
    return {
      rowspan: _row,
      colspan: _col
    }
  }
}

效果如圖!

完整代碼

最后把完整代碼貼上:

// ......
    mounted() {
      this.getSpanArr(this.tableListData.items, 'FirstIndex');
    },
    methods: {
      groupBy (data, params) {
        const groups = {}
        data.forEach(v => {
          const group = JSON.stringify(v[params])
          groups[group] = groups[group] || []
          groups[group].push(v)
        })
        return Object.values(groups)
      },
      getSpanArr (data, params) {
        let arr = []
        let pos = 0
        this.spanArr = []
        this.groupBy(data, params).map(v => (arr = arr.concat(v)))
        arr.map(res => {
          data.shift()
          data.push(res)
        })
        const redata = arr.map(v => v[params])
        redata.reduce((old, cur, i) => {
          if (i === 0) {
            this.spanArr.push(1)
            pos = 0
          } else {
            if (cur === old) {
              this.spanArr[pos] += 1
              this.spanArr.push(0)
            } else {
              this.spanArr.push(1)
              pos = i
            }
          }
          return cur
        }, {})
      },
      spanMethod({ row, column, rowIndex, columnIndex }) {
        if (columnIndex === 0) {
          const _row = this.spanArr[rowIndex];
          const _col = _row > 0 ? 1 : 0;
          return {
            rowspan: _row,
            colspan: _col
          }
        }
      }
    }

到此這篇關(guān)于Element中el-table動(dòng)態(tài)合并單元格(span-method方法)的文章就介紹到這了,更多相關(guān)Element el-table動(dòng)態(tài)合并單元格內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談vue單一組件下動(dòng)態(tài)修改數(shù)據(jù)時(shí)的全部重渲染

    淺談vue單一組件下動(dòng)態(tài)修改數(shù)據(jù)時(shí)的全部重渲染

    下面小編就為大家分享一篇淺談vue單一組件下動(dòng)態(tài)修改數(shù)據(jù)時(shí)的全部重渲染,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • el-select 下拉框多選實(shí)現(xiàn)全選的實(shí)現(xiàn)

    el-select 下拉框多選實(shí)現(xiàn)全選的實(shí)現(xiàn)

    這篇文章主要介紹了el-select 下拉框多選實(shí)現(xiàn)全選的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • vue解決跨域問題的幾種常用方法(CORS)

    vue解決跨域問題的幾種常用方法(CORS)

    在Vue中解決跨域問題有多種方法,今天通過本文給大家介紹幾種比較常見的方法,對(duì)vue解決跨域問題感興趣的朋友跟隨小編一起看看吧
    2023-05-05
  • vue slots 組件的組合/分發(fā)實(shí)例

    vue slots 組件的組合/分發(fā)實(shí)例

    今天小編就為大家分享一篇vue slots 組件的組合/分發(fā)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue中如何使用lodash的debounce防抖函數(shù)

    vue中如何使用lodash的debounce防抖函數(shù)

    防抖函數(shù) debounce 指的是某個(gè)函數(shù)在某段時(shí)間內(nèi),無論觸發(fā)了多少次回調(diào),都只執(zhí)行最后一次,在Vue中使用防抖函數(shù)可以避免在頻繁觸發(fā)的事件中重復(fù)執(zhí)行操作,這篇文章主要介紹了vue中使用lodash的debounce防抖函數(shù),需要的朋友可以參考下
    2024-01-01
  • vue中elementUI里面一些插件的使用

    vue中elementUI里面一些插件的使用

    Element UI是一套基于Vue的桌面端組件庫,封裝好了很多常用的UI組件,下面這篇文章主要給大家介紹了關(guān)于vue中elementUI里面一些插件的使用方法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • Vue偵測相關(guān)api的實(shí)現(xiàn)方法

    Vue偵測相關(guān)api的實(shí)現(xiàn)方法

    這篇文章主要介紹了Vue偵測相關(guān)api,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • vue攔截器Vue.http.interceptors.push使用詳解

    vue攔截器Vue.http.interceptors.push使用詳解

    這篇文章主要為大家詳細(xì)介紹了vue攔截器Vue.http.interceptors.push的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • 深入探討如何在Vue中使用EventBus實(shí)現(xiàn)組件間的高效通信

    深入探討如何在Vue中使用EventBus實(shí)現(xiàn)組件間的高效通信

    在現(xiàn)代前端開發(fā)中,Vue.js?作為一種流行的漸進(jìn)式框架,廣泛應(yīng)用于各類?Web?項(xiàng)目的構(gòu)建中,本文將深入探討如何在?Vue?中使用?EventBus,實(shí)現(xiàn)組件間的高效通信,需要的可以了解下
    2024-11-11
  • vue.js中$watch的用法示例

    vue.js中$watch的用法示例

    這篇文章為大家詳細(xì)介紹了vue.js中$watch的用法,文中給出了示例代碼,相信對(duì)大家的理解和學(xué)習(xí)具有一定的參考借鑒價(jià)值,有需要的朋友們可以一起看看吧。
    2016-10-10

最新評(píng)論