關(guān)于elementUi表格合并行數(shù)據(jù)并展示序號(hào)
效果如下:屬于同一個(gè)廠商的數(shù)據(jù)要合并成一行
element官網(wǎng)對(duì)于合并行和列是這樣說的:
通過給
table
傳入span-method
方法可以實(shí)現(xiàn)合并行或列,方法的參數(shù)是一個(gè)對(duì)象,里面包含當(dāng)前行row
、當(dāng)前列column
、當(dāng)前行號(hào)rowIndex
、當(dāng)前列號(hào)columnIndex
四個(gè)屬性。該函數(shù)可以返回一個(gè)包含兩個(gè)元素的數(shù)組,第一個(gè)元素代表rowspan
,第二個(gè)元素代表colspan
。 也可以返回一個(gè)鍵名為rowspan
和colspan
的對(duì)象。
實(shí)現(xiàn)合并行思路:需要一個(gè)數(shù)據(jù)來記錄需要合并的行數(shù)據(jù)(數(shù)字幾就代表合并幾行,比如 [1, 2, 0, 1]就是第一行第四行不變,第二三行合并成一行),還要有一個(gè)變量來記錄數(shù)組下標(biāo)。 注意:后臺(tái)返回的數(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: '序號(hào)', align: 'center', width: '100', scopedSlots: { customRender: 'serialNo' } }, { key: 'unionList', title: '廠商名稱(編號(hào))', 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ù)組下標(biāo) rowIndex: 1 // 序號(hào) } }, 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\":\"小太陽(yáng)\",\"union_id\":\"200734\"},{\"union_name\":\"包子\",\"union_id\":\"200737\"}]", unionName: '1012' }, { accessId: '3', id: 3, mqPassword: '1013', privateKey: '1013', publicKey: '1013', unionList: "[{\"union_name\":\"小太陽(yáng)\",\"union_id\":\"200734\"},{\"union_name\":\"包子\",\"union_id\":\"200737\"}]", unionName: '1013' }, { accessId: '4', id: 4, mqPassword: '1014', privateKey: '1014', publicKey: '1014', unionList: "[{\"union_name\":\"測(cè)試\",\"union_id\":\"200160\"}]", unionName: '1014' }, ] this.getSpanArr(this.tableData) // 獲取合并單元格數(shù)據(jù)和序號(hào) }, getSpanArr(data) { // 重新查詢后,要清空行數(shù)據(jù)數(shù)組、序號(hào)重置為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ù)并展示序號(hào)的文章就介紹到這了,更多相關(guān)elementUi表格合并內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談VueJS SSR 后端繪制內(nèi)存泄漏的相關(guān)解決經(jīng)驗(yàn)
這次我想給大家介紹的內(nèi)存泄漏的定位方法,并非工具的使用。而是一些經(jīng)驗(yàn)的總結(jié),也就是我所知道的 VueJS SSR 中最容易出現(xiàn)內(nèi)存泄漏的地方,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2018-12-12vue3中?provide?和?inject?用法小結(jié)
父子組件傳遞數(shù)據(jù)時(shí),使用的是props和emit,父?jìng)髯訒r(shí),使用的是?props,如果是父組件傳孫組件時(shí),就需要先傳給子組件,子組件再傳給孫組件,如果多個(gè)子組件或多個(gè)孫組件使用時(shí),就需要傳很多次,會(huì)很麻煩,這篇文章主要介紹了vue3中?provide?和?inject?用法,需要的朋友可以參考下2023-11-11Vue+ElementUI怎么處理超大表單實(shí)例講解
在本篇文章里小編給大家整理的是一篇關(guān)于Vue+ElementUI怎么處理超大表單實(shí)例講解內(nèi)容,以后需要的朋友可以跟著學(xué)習(xí)參考下。2021-11-11vue3+Element Plus實(shí)現(xiàn)自定義穿梭框的詳細(xì)代碼
找到一個(gè)好用的vue樹形穿梭框組件都很難,又不想僅僅因?yàn)橐粋€(gè)穿梭框在element-ui之外其他重量級(jí)插件,本文給大家分享vue3+Element Plus實(shí)現(xiàn)自定義穿梭框的示例代碼,感興趣的朋友一起看看吧2024-01-01vue實(shí)現(xiàn)動(dòng)態(tài)路由添加功能的簡(jiǎn)單方法(無廢話版本)
ue動(dòng)態(tài)路由(約定路由),聽起來好像很玄乎的樣子,但是你要是理解了實(shí)現(xiàn)思路,你會(huì)發(fā)現(xiàn)沒有想象中的那么難,下面這篇文章主要給大家介紹了關(guān)于vue實(shí)現(xiàn)動(dòng)態(tài)路由添加功能的簡(jiǎn)單方法,需要的朋友可以參考下2023-02-02Vue引入路徑正確但一直報(bào)錯(cuò)問題:Already included file name&n
這篇文章主要介紹了Vue引入路徑正確但一直報(bào)錯(cuò):Already included file name ‘××ב differs from file name ‘××ב only in casing.具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12Vue?ElementUI在el-table中使用el-popover問題
這篇文章主要介紹了Vue?ElementUI在el-table中使用el-popover問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04Vue中計(jì)算屬性和監(jiān)聽屬性及數(shù)據(jù)的響應(yīng)式更新和依賴收集基本原理講解
computed是vue的配置選項(xiàng),它的值是一個(gè)對(duì)象,其中可定義多個(gè)計(jì)算屬性,每個(gè)計(jì)算屬性就是一個(gè)函數(shù),下面這篇文章主要給大家介紹了關(guān)于vue中計(jì)算屬性computed的詳細(xì)講解,需要的朋友可以參考下2023-03-03通過vue.extend實(shí)現(xiàn)消息提示彈框的方法記錄
這篇文章主要給大家介紹了關(guān)于通過vue.extend實(shí)現(xiàn)消息提示彈框的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01