vue復(fù)雜表格單元格合并根據(jù)數(shù)據(jù)動(dòng)態(tài)合并方式
我們?cè)陂_發(fā)中最常見的就是表格,而往往有一些復(fù)雜表格都不大好實(shí)現(xiàn),對(duì)于合并單元格不是固定的,而是需要根據(jù)數(shù)據(jù)是否相同去動(dòng)態(tài)設(shè)置合并的表格
本文把方法分享給大家,可以根據(jù)數(shù)據(jù)動(dòng)態(tài)生成合并單元格,無(wú)論導(dǎo)出需求還是顯示需求都不需要發(fā)愁了。
使用element的span-method方法實(shí)現(xiàn)合并
首先繪制表格,綁定合并方法:span-method=“objectSpanMethod4”
<!-- 列的合并 --> <el-table ref="tableDD4" id="tableDD4" :data="tableData4" :span-method="objectSpanMethod" max-height="600" border> <el-table-column label="一級(jí)表頭" align="left"> <el-table-column label="二級(jí)表頭1" prop="firstCatalogue" align="left" width="300" /> <el-table-column label="二級(jí)表頭2" prop="secondCatalogue" align="left" /> <el-table-column label="二級(jí)表頭3" prop="insuranceName" align="left" width="140" /> <el-table-column label="二級(jí)表頭4" prop="isMatch" align="left" width="130" /> </el-table-column> </el-table>
首先設(shè)置變量margeArray4,用來(lái)存儲(chǔ)rowspan()方法計(jì)算出來(lái)的每一列單元格合并列數(shù)
rowspan()方法詳細(xì)介紹
index === 0,第一行,直接先給數(shù)組 push 進(jìn)一個(gè)1,表示自己先占一行,position 是數(shù)組元素的位置
(此時(shí)是從數(shù)組元素的第一個(gè)開始,所以position 為 0), position為 0 意思表示的就是數(shù)組的第一個(gè)元素
index 為 2 的時(shí)候,讓第二行與第一行作比較:
(1)如果第二行與第一行相等的話,spanArr[position] 就 +1,當(dāng)有 n 行第一行相同,spanArr[position] 就為 n,表示向下合并 n 行;
第二行自己就 spanArr.push(0),表示第二行“消失”,因?yàn)榈谝恍泻偷诙泻喜⒘耍?nbsp;
(2)如果第二行與第一行不相等的話,那么 spanArr.push(1);就讓第二行自己獨(dú)占一行;
更新position = index :把指針拿到 index 這行來(lái),用來(lái)設(shè)置數(shù)組 spanArr[position] 的合并情況元素值,然后定義從此行開始向下合并幾行
data() { return { //接收后端數(shù)據(jù) tableData1: [], //存儲(chǔ)每一列合并行以及下標(biāo)數(shù)據(jù) margeArray: [], } },
rowspan(tableData, spanArr, position, spanName) { tableData.forEach((item, index) => { if (index === 0) { spanArr.push(1); position = 0; } else { if (tableData[index][spanName] === tableData[index - 1][spanName]) { spanArr[position] += 1; spanArr.push(0); } else { spanArr.push(1); position = index; } } }); },
objectSpanMethod方法的實(shí)現(xiàn):
// 表格合并行 objectSpanMethod({ row, column, rowIndex, columnIndex }) { // 計(jì)算一共有幾列數(shù)據(jù) let arraynum = Object.keys(this.tableData1[0]).length for (let i = 0; i < 2; i++) { if (columnIndex == i) { const _row = this.margeArray[i].Arr[rowIndex]; const _col = _row > 0 ? 1 : 0; return { rowspan: _row, colspan: _col, }; } } },
axios請(qǐng)求數(shù)據(jù)之后,調(diào)用計(jì)算合并行,實(shí)現(xiàn)合并
//此處是我封裝好的請(qǐng)求方法,你自己的實(shí)際情況修改即可 this.$postRequest('/basicSystem/export/sheet1', { year: this.year }).then(({ data }) => { //判斷請(qǐng)求狀態(tài)為success/false,請(qǐng)求成功,處理數(shù)據(jù),否則輸出錯(cuò)誤信息 if (data && data.type === 'success') { //接收后端返回的數(shù)據(jù) this.tableData1 = data.data //開始 調(diào)用方法計(jì)算需要合并的數(shù)據(jù) for (let i = 0; i < Object.keys(this.tableData1[0]).length; i++) { // 首先添加一個(gè)存放合并行數(shù)據(jù)的變量 this.margeArray.push({ Arr: [], Position: 0, }) // 得到下標(biāo)對(duì)應(yīng)的key值 const element = Object.keys(this.tableData1[0])[i]; // 調(diào)用合并, this.rowspan(this.tableData1, this.margeArray[i].Arr, this.margeArray[i].Position, element); } } else { this.$message.error(data.message) } }).catch(error => { this.$message.error(error) })
最后說(shuō)一個(gè)很重要的點(diǎn)
注意:
此處因?yàn)槭莿?dòng)態(tài)根據(jù)后端反的數(shù)據(jù)的key值去計(jì)算對(duì)應(yīng)列的合并情況
所以必須!必須!必須!要保證后端返回的數(shù)據(jù)里key值順序,要和前端table的展示順序一直,否則合并會(huì)出錯(cuò)。
舉例
前端頁(yè)面table展示順序:firstCatalogue為第一個(gè),secondCatalogue為第二個(gè)以此類推
同樣后端返回json數(shù)據(jù)中key順序:firstCatalogue為第一個(gè),secondCatalogue為第二個(gè)以此類
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
基于elementUI使用v-model實(shí)現(xiàn)經(jīng)緯度輸入的vue組件
這篇文章主要介紹了基于elementUI使用v-model實(shí)現(xiàn)經(jīng)緯度輸入的vue組件,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05關(guān)于在vue 中使用百度ueEditor編輯器的方法實(shí)例代碼
這篇文章主要介紹了在vue 中使用百度ueEditor編輯器的方法實(shí)例代碼 ,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09vue自定義組件如何通過(guò)v-model指令控制組件的隱藏、顯示
這篇文章主要介紹了vue自定義組件如何通過(guò)v-model指令控制組件的隱藏、顯示,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05vue中v-for通過(guò)動(dòng)態(tài)綁定class實(shí)現(xiàn)觸發(fā)效果
這篇文章主要介紹了vue中v-for通過(guò)動(dòng)態(tài)綁定class實(shí)現(xiàn)觸發(fā)效果,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-12-12vue 數(shù)組和對(duì)象不能直接賦值情況和解決方法(推薦)
這篇文章主要介紹了vue 數(shù)組和對(duì)象不能直接賦值情況和解決方法,需要的朋友可以參考下2017-10-10Vue?Router嵌套路由(children)的用法小結(jié)
嵌套路由就是父路由里面嵌套他的子路由,父路由有自己的路由導(dǎo)航和路由容器(router-link、router-view),通過(guò)配置children可實(shí)現(xiàn)多層嵌套,這篇文章主要介紹了Vue--Router--嵌套路由(children)的用法,需要的朋友可以參考下2022-08-08vue-cli 環(huán)境變量 process.env的使用及說(shuō)明
這篇文章主要介紹了vue-cli 環(huán)境變量 process.env的使用及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12