el-tree代碼,主要加入了draggable屬性和node-drop和handleDragEnd事件
<el-tree
node-key="id"
default-expand-all
:data="collectionList"
:props="defaultProps"
:expand-on-click-node="false"
:filter-node-method="filterNode"
highlight-current
ref="tree"
style="margin-top: 10px"
@node-drag-end="handleDragEnd"
@node-drop="handleDrop"
draggable
:allow-drop="allowDrop">
handleDrop事件代碼
// 拖拽事件 參數依次為:被拖拽節點對應的 Node、結束拖拽時最后進入的節點、被拖拽節點的放置位置(before、after、inner)、event
handleDrop: async function(draggingNode, dropNode, dropType, ev) {
var paramData = [];
// 當拖拽類型不為inner,說明只是同級或者跨級排序,只需要尋找目標節點的父ID,獲取其對象以及所有的子節點,並為子節點設置當前對象的ID為父ID即可
// 當拖拽類型為inner,說明拖拽節點成為了目標節點的子節點,只需要獲取目標節點對象即可
var data = dropType != "inner" ? dropNode.parent.data : dropNode.data;
var nodeData = dropNode.level == 1 && dropType != "inner" ? data : data.children;
// 設置父ID,當level為1說明在第一級,pid為0
nodeData.forEach(element => {
element.pid = dropNode.level == 1 ? 0 : data.id;
});
nodeData.forEach((element, i) => {
var collection = {
collectionId: element.id,
parentId: element.pid,
sort: i+1
};
paramData.push(collection);
});
this.loading = true;
updateCollection(JSON.stringify(paramData)).then(response => {
this.msgSuccess("排序成功");
this.loading = false;
});
},
后端接收前端傳入的數組數據批量修改即可
