如何使用Vue和Element-UI實現拖曳排序功能
前言:
在Web開發中,拖曳排序功能是一項常見且實用的功能。本文將介紹如何使用Vue和Element-UI來實現拖曳排序功能,透過程式碼範例示範實作過程。
一、環境建置
npm install -g @vue/cli
vue create drag-sort-demo
依照提示選擇設定選項並等待專案建立完成。
npm install element-ui
二、實作拖曳排序功能
import Vue from 'vue';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
Vue.use(ElementUI);
d477f9ce7bf77f53fbcf36bec1b69b7a
dc6dce4a544fdca2df29d5ac0ea9906b
<div class="drag-sort-demo"> <el-collapse-transition> <div v-for="item in list" :key="item.id" class="drag-item" :class="{ 'dragging': draggingId === item.id }" draggable="true" @dragstart="handleDragStart(item)" @dragend="handleDragEnd(item)"> {{ item.name }} </div> </el-collapse-transition> </div> <el-button type="primary" @click="handleSort">保存排序</el-button>
16b28748ea4df4d9c2150843fecfba68
21c97d3a051048b8e55e3c8f199a54b2
3f1c4e4b6b16bbbd69b2ee476dc4f83a
export default {
data() {
return { list: [ { id: 1, name: 'A' }, { id: 2, name: 'B' }, { id: 3, name: 'C' }, { id: 4, name: 'D' }, { id: 5, name: 'E' }, ], draggingId: null, };
},
methods: {
handleDragStart(item) { this.draggingId = item.id; }, handleDragEnd() { this.draggingId = null; }, handleSort() { const sortedList = Array.from(this.$el.querySelectorAll('.drag-item')).map((el, index) => { const id = el.getAttribute('data-id'); const name = el.textContent; return { id, name, sort: index + 1 }; }); // 将排序后的列表保存到数据库或发送给后端 },
},
};
2cacc6d41bbb37262a98f745aa00fbf0
30e8033e360bcffb1ce9b4703e10b64c
.drag-sort-demo {
display: flex;
flex-wrap: wrap;
}
.drag-item {
padding: 10px;
margin: 10px 0;
background-color: #f5f5f5;
border: 1px solid #ebebeb;
cursor: move;
transition: box-shadow 0.3s;
}
.drag-item.dragging {
box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}
531ac245ce3e4fe3d50054a55f265927
解釋:
d477f9ce7bf77f53fbcf36bec1b69b7a
e0a127155eaad306e6803a1b3b80da90
<drag-sort-demo></drag-sort-demo>
16b28748ea4df4d9c2150843fecfba68
21c97d3a051048b8e55e3c8f199a54b2
3f1c4e4b6b16bbbd69b2ee476dc4f83a
import DragSortDemo from './components/DragSortDemo.vue' ;
export default {
components: {
DragSortDemo,
},
};
2cacc6d41bbb37262a98f745aa00fbf0
三、執行專案
在命令列中執行下列指令啟動項目:
npm run serve
造訪http://localhost:8080即可看到拖曳排序功能的示範頁面。拖曳清單項目即可改變排序,並點選儲存排序按鈕將排序結果儲存。
結語:
透過上述步驟,我們成功地使用Vue和Element-UI實作了拖曳排序功能。這為我們的Web開發提供了一個簡單而實用的方案,能夠提升使用者體驗並優化介面互動。希望本文能對大家的前端開發工作有幫助。
以上是如何使用Vue和Element-UI實現拖曳排序功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!