vue中如何使用elementUI表格動(dòng)態(tài)行合并
vue 使用elementUI表格動(dòng)態(tài)行合并
需求背景
在開發(fā)中又是表格合并的行數(shù)并不是固定的行數(shù),需要根據(jù)接口返回的數(shù)據(jù)來動(dòng)態(tài)合并需要合并的行數(shù)
html代碼:
<el-table
:data="tableData"
border
:span-method="objectSpanMethod"
>
<el-table-column label="前面" align="center">
<el-table-column prop="inquiryCode" label="id" align="center" />
<el-table-column prop="phoneNumber" label="1" align="center" />
<el-table-column prop="createTime" label="2" align="center" />
<el-table-column prop="createTime" label="3" align="center" />
<el-table-column prop="contractCount" label="4" align="center" />
</el-table-column>
<el-table-column label="中間" align="center">
<el-table-column prop="bankName" label="6" align="center" />
<el-table-column prop="acceptanceAmount" label="7" align="center" />
<el-table-column prop="dueTime" label="8" align="center" />
<el-table-column prop="dueDay" label="9" align="center" />
<el-table-column prop="interestAmount" label="10" align="center" />
</el-table-column>
<el-table-column label="總計(jì)" align="center">
<el-table-column prop="cashPayAmount" label="11" align="center" />
<el-table-column prop="acceptanceAllAmount" label="12" align="center" />
<el-table-column prop="payAllAmount" label="13" align="center" />
<el-table-column prop="interestAllAmount" label="14" align="center" />
</el-table-column>
</el-table>js代碼:(注意:此處我是根據(jù)接口返回的inquiryCode是否相同來確實(shí)是否需要合并,你如果是其他字段自行更改)
export default {
data() {
return {
tableData: [],
spanArr: [],
}
},
mounted() {
this.rowspan();
},
methods: {
rowspan() {
// 每次調(diào)用清空數(shù)據(jù)
this.spanArr = []
this.position = 0
this.tableData.forEach((item, index) => {
if (index === 0) {
this.spanArr.push(1)
this.position = 0
} else {
// inquiryCode 為需要合并查詢的項(xiàng)
if (this.tableData[index].inquiryCode === this.tableData[index - 1].inquiryCode) {
this.spanArr[this.position] += 1
this.spanArr.push(0)
} else {
this.spanArr.push(1)
this.position = index
}
}
})
},
objectSpanMethod({ row, column, rowIndex, columnIndex }) {
if (columnIndex === 0 || columnIndex === 1 || columnIndex === 2 || columnIndex === 3 || columnIndex === 4 || columnIndex === 10 || columnIndex === 11 || columnIndex === 12 || columnIndex === 13) {
const _row = this.spanArr[rowIndex]
const _col = _row > 0 ? 1 : 0
return {
rowspan: _row,
colspan: _col
}
}
},
}
}效果截圖:

vue elementUI動(dòng)態(tài)刪除表格當(dāng)前行內(nèi)容
具體步驟
第一步:拿到當(dāng)前行數(shù)據(jù)的索引
第二部:綁定函數(shù)置刪除鍵將拿到的數(shù)據(jù)索引通過請(qǐng)求發(fā)送給后端
第三部,調(diào)用獲取數(shù)據(jù)借口(這樣就不用刪除數(shù)據(jù)后還要再次刷新頁(yè)面,用戶體驗(yàn)會(huì)更好)
實(shí)現(xiàn)方法
首先獲取將要被刪除行的數(shù)據(jù)索引
<el-card class="box-card">
<el-table
:data="tableData"
border
stripe
style="width: 100% "
@selection-change="handleSelectionChange"
>
<el-table-column type="selection" width="55" align="center"></el-table-column>
<el-table-column prop="id" label="學(xué)號(hào)" align="center"></el-table-column>
<el-table-column prop="name" label="姓名" align="center"></el-table-column>
<el-table-column prop="sex" label="性別" align="center"></el-table-column>
<el-table-column prop="college" label="學(xué)院" align="center"></el-table-column>
<el-table-column label="操作" align="center">
<template slot-scope="scope" class="active">
<el-button @click="editData(scope.row)" type="primary" icon="el-icon-edit" circle></el-button>
<el-button @click="removeData(scope.row.id)" type="danger" icon="el-icon-delete" circle></el-button>
</template>
</el-table-column>
</el-table>
<el-row :gutter="20">
<el-col :span="6" :offset="12">
<div class="block">
<el-pagination
background
@current-change="handleCurrentChange"
:current-page.sync="currentPage"
:page-size="pageSize"
layout="total, prev, next, jumper, pager"
:total="total"
></el-pagination>
</div>
</el-col>
</el-row>
</el-card>
在這一步中,獲取當(dāng)行數(shù)據(jù)使用的方法是 scope.row.id 。這將把當(dāng)行數(shù)據(jù)的id傳遞給刪除函數(shù)
接下來就是刪除函數(shù)的邏輯實(shí)現(xiàn)了
在這一步中需要注意的是,請(qǐng)求成功后應(yīng)該調(diào)用一次獲取數(shù)據(jù)列表的函數(shù),否則需要刷行頁(yè)面才看得到刪除的效果
removeData(id) {
//提示框,判斷用戶是否操作失誤
this.$confirm("此操作將永久刪除此學(xué)生, 是否繼續(xù)?", "警告", {
confirmButtonText: "繼續(xù)",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
const data = { id }; //這里<=>data = {id:id}
axios
.post("URL", data)
.then(response => {
this.fetchdata(); //刪除數(shù)據(jù)后重新獲取數(shù)據(jù)
})
.catch(() => {
this.$message({
type:"warning",
message:"請(qǐng)求失敗,請(qǐng)檢查網(wǎng)絡(luò)設(shè)置"
})
});
})
.catch(() => {
this.$message({
type: "info",
message: "已取消刪除"
});
});
}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 基于Vue?+?ElementUI實(shí)現(xiàn)可編輯表格及校驗(yàn)
- Vue+EleMentUI實(shí)現(xiàn)el-table-colum表格select下拉框可編輯功能實(shí)例
- vue+elementUI的表格最后一行合計(jì)自定義顯示方式
- Vue+ElementUi實(shí)現(xiàn)點(diǎn)擊表格中鏈接進(jìn)行頁(yè)面跳轉(zhuǎn)與路由詳解
- vue elementui表格獲取某行數(shù)據(jù)(slot-scope和selection-change方法使用)
- vue+elementUI顯示表格指定列合計(jì)數(shù)據(jù)方式
相關(guān)文章
vue實(shí)現(xiàn)動(dòng)態(tài)數(shù)據(jù)綁定
本篇文章主要介紹了vue實(shí)現(xiàn)動(dòng)態(tài)數(shù)據(jù)綁定,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04
vue-cli3.0 axios跨域請(qǐng)求代理配置方式及端口修改
這篇文章主要介紹了vue-cli3.0 axios跨域請(qǐng)求代理配置方式及端口修改,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
vue如何根據(jù)網(wǎng)站路由判斷頁(yè)面主題色詳解
這篇文章主要給大家介紹了關(guān)于vue如何根據(jù)網(wǎng)站路由判斷頁(yè)面主題色的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11
vue3的defineExpose宏函數(shù)是如何暴露方法給父組件使用
當(dāng)子組件使用setup后,父組件就不能像vue2那樣直接就可以訪問子組件內(nèi)的屬性和方法,這個(gè)時(shí)候就需要在子組件內(nèi)使用defineExpose宏函數(shù)來指定想要暴露出去的屬性和方法,本文介紹vue3的defineExpose宏函數(shù)是如何暴露方法給父組件使用,需要的朋友可以參考下2024-05-05
用vue實(shí)現(xiàn)注冊(cè)頁(yè)效果?vue實(shí)現(xiàn)短信驗(yàn)證碼登錄
這篇文章主要為大家詳細(xì)介紹了用vue實(shí)現(xiàn)注冊(cè)頁(yè),短信驗(yàn)證碼登錄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
Vue.js項(xiàng)目中管理每個(gè)頁(yè)面的頭部標(biāo)簽的兩種方法
這篇文章主要介紹了Vue.js項(xiàng)目中管理每個(gè)頁(yè)面的頭部標(biāo)簽的兩種方法,需要的朋友可以參考下2018-06-06

