【开发记录】vue3实现列表拖拽排序,如何阻止放下后,元素回落?

一、问题描述

写了一个列表的拖拽排序,但遇到一个问题,就是拖拽放下后,html元素总会有一个回落的默认效果,这个会影响排序效果。

二、解决

其实,最后解决的办法,也很简单,就是在dragover事件处理中,去除默认,也就是e.preventDefault();

js 复制代码
 const onDragOver = (e: any, index: number) => {
    e.preventDefault();
    // ....
 }

三、最后,记录一下完整的代码实现

vue3 复制代码
<template>
  <div>
    <div class="card-list">
      <div
        class="card-item"
        :class="{'drag-over': dragOverIndex === index, 'active': dragData.index == index}"
        v-for="(item, index) in dataList"
        :key="item.cocosData.id"
        :id="item.cocosData.id"
        draggable="true"
        @dragstart.stop="onDragStart($event, index)"
        @dragover.stop="onDragOver($event, index)"
        @dragend.stop="onDragend"
      >
        <span>{{ item }}</span>
      </div>
    </div>
  </div>
</template>

<script lang="ts">
import { ref } from "vue";

export default defineComponent({
    name: "DragSort",
    setup(props) {
        const dataList = ref<string[]>([
            "字母A",
            "字母B",
            "字母D",
            "p",
        ]);
        
        const dragData = ref<any>({});
        const onDragStart = (e: any, index: number) => {
          dragData.value = {
            index,
          }
        }
        const dragOverIndex = ref(-1);
        const onDragOver = (e: any, index: number) => {
          e.preventDefault();
          if (dragData.value.index != index) {
            dragOverIndex.value = index;
          } else {
            dragOverIndex.value = -1;
          }
        }
        const onDragend = (e: any) => {
          e.preventDefault();
          const dragIndex = dragData.value.index;
          console.log('onDragend', dragIndex, dragOverIndex.value);
          if (dragIndex != dragOverIndex.value && dragOverIndex.value != -1) {
            const dragItem = _.cloneDeep(cocosdata.value["children"][dragIndex]);
            console.log('dragItem', dragItem);
            if (dragOverIndex.value > dragIndex) {
              cocosdata.value["children"].splice(dragOverIndex.value + 1, 0, dragItem);
              cocosdata.value["children"].splice(dragIndex, 1);
            } else {
              cocosdata.value["children"].splice(dragIndex, 1);
              cocosdata.value["children"].splice(dragOverIndex.value, 0, dragItem);
            }
          }
          dragOverIndex.value = -1;
          dragData.value = {};
        }
        
        return {
          dataList,
          onDragStart,
          onDragOver,
          dragOverIndex,
          onDragend,
          dragData,
        };
    },
});

</script>

<style lang="less" scoped>
.card-list {
  margin-top: 10px;
  .card-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 1px solid transparent;
    position: relative;
    &.active {
      background-color: #f2f2f2;
    }
    &.drag-over {
      background-color: #ddd;
      border: 1px solid #aaa;
    }
    span {
      cursor: pointer;
    }
  }
}
</style>

四、最后

欢迎各位来用下我用了近2年,搞的一款网页编辑器,一定会让你感到惊讶的,哈哈!

相关推荐
C_心欲无痕2 分钟前
网络相关 - Ngrok内网穿透使用
运维·前端·网络
咖啡の猫3 分钟前
TypeScript-Babel
前端·javascript·typescript
Mintopia29 分钟前
🤖 AI 决策 + 意图OS:未来软件形态的灵魂共舞
前端·人工智能·react native
攀登的牵牛花30 分钟前
前端向架构突围系列 - 框架设计(四):依赖倒置原则(DIP)
前端·架构
程序员爱钓鱼37 分钟前
Node.js 编程实战:测试与调试 —— 日志与监控方案
前端·后端·node.js
计算机学姐43 分钟前
基于SpringBoot的汉服租赁系统【颜色尺码套装+个性化推荐算法+数据可视化统计】
java·vue.js·spring boot·后端·mysql·信息可视化·推荐算法
+VX:Fegn089544 分钟前
计算机毕业设计|基于springboot + vue建筑材料管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
Mapmost1 小时前
数字孪生项目效率翻倍!AI技术实测与场景验证实录
前端
小酒星小杜1 小时前
在AI时代,技术人应该每天都要花两小时来构建一个自身的构建系统-Input篇
前端·程序员·架构