亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

elementUi表格合并行數據并展示序號的方法是什么

發布時間:2023-04-25 10:07:34 來源:億速云 閱讀:193 作者:iii 欄目:開發技術

今天小編給大家分享一下elementUi表格合并行數據并展示序號的方法是什么的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

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

elementUi表格合并行數據并展示序號的方法是什么

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表格合并行數據并展示序號的方法是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

铜陵市| 禹城市| 梁山县| 天津市| 太谷县| 江华| 永仁县| 宜良县| 台南县| 綦江县| 三亚市| 定安县| 石首市| 武邑县| 莱西市| 静宁县| 莱州市| 息烽县| 高邮市| 西平县| 西畴县| 湟源县| 宁夏| 喜德县| 哈密市| 杭州市| 灵川县| 习水县| 荣昌县| 白玉县| 永川市| 浏阳市| 缙云县| 泗阳县| 板桥市| 札达县| 榕江县| 博罗县| 鞍山市| 同仁县| 嫩江县|