亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

關(guān)于elementUi表格合并行數(shù)據(jù)并展示序號

 更新時間:2023年04月25日 08:40:35   作者:小太陽...  
這篇文章主要介紹了關(guān)于elementUi表格合并行數(shù)據(jù)并展示序號,通過給table傳入span-method方法可以實現(xiàn)合并行或列,方法的參數(shù)是一個對象,感興趣的朋友可以學(xué)習(xí)一下

效果如下:屬于同一個廠商的數(shù)據(jù)要合并成一行

在這里插入圖片描述

element官網(wǎng)對于合并行和列是這樣說的:

通過給table傳入span-method方法可以實現(xiàn)合并行或列,方法的參數(shù)是一個對象,里面包含當(dāng)前行row、當(dāng)前列column、當(dāng)前行號rowIndex、當(dāng)前列號columnIndex四個屬性。該函數(shù)可以返回一個包含兩個元素的數(shù)組,第一個元素代表rowspan,第二個元素代表colspan。 也可以返回一個鍵名為rowspancolspan的對象。

實現(xiàn)合并行思路:需要一個數(shù)據(jù)來記錄需要合并的行數(shù)據(jù)(數(shù)字幾就代表合并幾行,比如 [1, 2, 0, 1]就是第一行第四行不變,第二三行合并成一行),還要有一個變量來記錄數(shù)組下標。 注意:后臺返回的數(shù)據(jù)一定要有能區(qū)分唯一性的數(shù)據(jù),來判斷前后兩條數(shù)據(jù)是否一樣。 主要代碼如下:

    <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: [], // 存合并行數(shù)據(jù)的數(shù)組
      pos: 0,// 合并行數(shù)據(jù)數(shù)組下標
      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) // 獲取合并單元格數(shù)據(jù)和序號
    },
    getSpanArr(data) {
    // 重新查詢后,要清空行數(shù)據(jù)數(shù)組、序號重置為1
      this.spanArr = []
      this.rowIndex = 1
      // 遍歷數(shù)據(jù),判斷前后兩條數(shù)據(jù)是否相同
      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 {
          // 判斷當(dāng)前元素與上一元素是否相同
          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
        }
      }
    },
  }
}

到此這篇關(guān)于關(guān)于elementUi表格合并行數(shù)據(jù)并展示序號的文章就介紹到這了,更多相關(guān)elementUi表格合并內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談VueJS SSR 后端繪制內(nèi)存泄漏的相關(guān)解決經(jīng)驗

    淺談VueJS SSR 后端繪制內(nèi)存泄漏的相關(guān)解決經(jīng)驗

    這次我想給大家介紹的內(nèi)存泄漏的定位方法,并非工具的使用。而是一些經(jīng)驗的總結(jié),也就是我所知道的 VueJS SSR 中最容易出現(xiàn)內(nèi)存泄漏的地方,非常具有實用價值,需要的朋友可以參考下
    2018-12-12
  • vue3中?provide?和?inject?用法小結(jié)

    vue3中?provide?和?inject?用法小結(jié)

    父子組件傳遞數(shù)據(jù)時,使用的是props和emit,父傳子時,使用的是?props,如果是父組件傳孫組件時,就需要先傳給子組件,子組件再傳給孫組件,如果多個子組件或多個孫組件使用時,就需要傳很多次,會很麻煩,這篇文章主要介紹了vue3中?provide?和?inject?用法,需要的朋友可以參考下
    2023-11-11
  • Vue+ElementUI怎么處理超大表單實例講解

    Vue+ElementUI怎么處理超大表單實例講解

    在本篇文章里小編給大家整理的是一篇關(guān)于Vue+ElementUI怎么處理超大表單實例講解內(nèi)容,以后需要的朋友可以跟著學(xué)習(xí)參考下。
    2021-11-11
  • vue3+Element Plus實現(xiàn)自定義穿梭框的詳細代碼

    vue3+Element Plus實現(xiàn)自定義穿梭框的詳細代碼

    找到一個好用的vue樹形穿梭框組件都很難,又不想僅僅因為一個穿梭框在element-ui之外其他重量級插件,本文給大家分享vue3+Element Plus實現(xiàn)自定義穿梭框的示例代碼,感興趣的朋友一起看看吧
    2024-01-01
  • vue實現(xiàn)動態(tài)路由添加功能的簡單方法(無廢話版本)

    vue實現(xiàn)動態(tài)路由添加功能的簡單方法(無廢話版本)

    ue動態(tài)路由(約定路由),聽起來好像很玄乎的樣子,但是你要是理解了實現(xiàn)思路,你會發(fā)現(xiàn)沒有想象中的那么難,下面這篇文章主要給大家介紹了關(guān)于vue實現(xiàn)動態(tài)路由添加功能的簡單方法,需要的朋友可以參考下
    2023-02-02
  • Vue引入路徑正確但一直報錯問題:Already included file name ‘××ב differs from file name ‘××ב only in casing.

    Vue引入路徑正確但一直報錯問題:Already included file name&n

    這篇文章主要介紹了Vue引入路徑正確但一直報錯:Already included file name ‘××ב differs from file name ‘××ב only in casing.具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Vue?ElementUI在el-table中使用el-popover問題

    Vue?ElementUI在el-table中使用el-popover問題

    這篇文章主要介紹了Vue?ElementUI在el-table中使用el-popover問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Vue中計算屬性和監(jiān)聽屬性及數(shù)據(jù)的響應(yīng)式更新和依賴收集基本原理講解

    Vue中計算屬性和監(jiān)聽屬性及數(shù)據(jù)的響應(yīng)式更新和依賴收集基本原理講解

    computed是vue的配置選項,它的值是一個對象,其中可定義多個計算屬性,每個計算屬性就是一個函數(shù),下面這篇文章主要給大家介紹了關(guān)于vue中計算屬性computed的詳細講解,需要的朋友可以參考下
    2023-03-03
  • 基于vue的tab-list類目切換商品列表組件的示例代碼

    基于vue的tab-list類目切換商品列表組件的示例代碼

    這篇文章主要介紹了基于vue的tab-list類目切換商品列表組件的示例代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • 通過vue.extend實現(xiàn)消息提示彈框的方法記錄

    通過vue.extend實現(xiàn)消息提示彈框的方法記錄

    這篇文章主要給大家介紹了關(guān)于通過vue.extend實現(xiàn)消息提示彈框的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01

最新評論