場景:el-table,type="selection"時,從新請求後,設置列表更新前的已勾選項html
踩坑:在翻頁或者changPageSize以後,table的data會更新,以前勾選的選項會被清掉this
初次嘗試:spa
最快速的解決辦法以下:3d
element-UI 的table表格數據有提供多項框的功能,只要在表格列中多加一列就能夠選擇表格的數據code
<el-table :data="tableData6" :row-key="getRowKey" ref="buyerTable" height="300" @selection-change="handleSelectionChange" border style="width: 100%"> <el-table-column type="selection" :reserve-selection="true" width="55"> </el-table-column> <el-table-column prop="id" label="ID" width="180"> </el-table-column> <el-table-column prop="name" label="姓名"> </el-table-column> <el-table-column prop="amount1" sortable label="數值 1"> </el-table-column> <el-table-column prop="amount2" sortable label="數值 2"> </el-table-column> <el-table-column prop="amount3" sortable label="數值 3"> </el-table-column> </el-table> <el-pagination @size-change="handleBuyerSizeChange" @current-change="handleBuyerCurrentChange" :current-page="currentBuyerPage" :page-sizes="[5, 10, 15, 20]" :page-size="buyerPageSize" layout="total, sizes, prev, pager, next, jumper" :total="buyerTotalCount"> </el-pagination>
js代碼:htm
methods: { // 保存選中的數據id,row-key就是要指定一個key標識這一行的數據 getRowKey (row) { return row.id }, // 列表選擇,val選中的表格行數據 handleSelectionChange (val) { console.log(val) }, // 清空選擇的值 clearSelect () { this.$refs.buyerTable.clearSelection() } }
注意:blog
row.id 最好不要重複,否則會報錯了,若是id有重複的能夠採用以下解決辦法來設置不一樣的id值
this.recordList = data.content.map((v,index) => { this.$set(v, 'id', v.messageId+index) return v })