您好,登錄后才能下訂單哦!
這篇文章主要介紹“Vue怎么實現table列表項上下移動”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Vue怎么實現table列表項上下移動”文章能幫助大家解決問題。
結合Element組件,scope中有三個參數(row,cow,$index)分別表示行內容、列內容、以及此行索引值,
table上綁定數組 :data=“newsList”。
上移和下調兩個按鈕,并綁定上點擊函數,將此行的索引值(scope.$index)作為參數:
<template> <el-table :data="newsList"> <el-table-column type="index" label="序號" width="50"></el-table-column> <el-table-column prop="title" label="文章標題" min-width="300" ></el-table-column> <el-table-column prop="descript" label="文章描述" min-width="300" ></el-table-column> <el-table-column label="操作(素材排序)" > <template slot-scope="scope"> <el-button size="mini" type='text' @click.stop="sortUp(scope.$index, scope.row)">向上↑ </el-button> <el-button size="mini" type='text' @click.stop="sortDown(scope.$index, scope.row)">向下↓</el-button> </template> </el-table-column> </el-table> </template>
上移下移函數,此處的坑,是vue視圖更新!!!
直接使用下面這種方式是錯誤的,雖然tableList的值變了,但是不會觸發視圖的更新:
upFieldOrder (index) { let temp = this.tableList[index-1]; this.tableList[index-1] = this.tableList[index] this.tableList[index] = temp },
正確方法:
// 上移按鈕 sortUp (index, row) { if (index === 0) { this.$message({ message: '已經是列表中第一個素材!', type: 'warning' }) } else { let temp = this.newsList[index - 1] this.$set(this.newsList, index - 1, this.newsList[index]) this.$set(this.newsList, index, temp) } },
同理,下移函數,
// 下移按鈕 sortDown (index, row) { if (index === (this.newsList.length - 1)) { this.$message({ message: '已經是列表中最后一個素材!', type: 'warning' }) } else { let i = this.newsList[index + 1] this.$set(this.newsList, index + 1, this.newsList[index]) this.$set(this.newsList, index, i) } }
效果圖:
關于“Vue怎么實現table列表項上下移動”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。