vue3项目,使用sortablejs对图片进行拖拽排序

安装:

插件地址:https://www.npmjs.com/package/sortablejs

复制代码
npm install sortablejs --save

pnpm add sortablejs --save

实现效果:

具体代码:

template部分的代码:

html 复制代码
<div class="imgList flex mt-5" ref="uploadImgItem">
          <div v-for="item in imgList" :key="item.fileOrder" class="imgItem">
            <!-- <img :src="item.url" alt="" v-if="item.fileType === 'image'" /> -->
            <el-image
              v-if="item.fileType === 'image'"
              style="width: 108px; height: 108px"
              :src="item.url"
              :zoom-rate="1.2"
              :max-scale="7"
              :min-scale="0.2"
              :preview-src-list="[item.url]"
              :initial-index="4"
              fit="cover"
            >
              <template #error>
                <div
                  style="width: 108px; height: 108px"
                  class="image-slot flex justify-center items-center"
                  @click="uploadErrorImgItem(item)"
                >
                  重新加载
                </div>
              </template>
            </el-image>
            <video
              :src="item.url"
              v-if="item.fileType === 'video'"
              ref="video"
              controls
              @pause="onVideoPause"
            ></video>
            <div
              @click="playVideo(item.url)"
              class="videoMask flex items-center justify-center"
              v-if="item.fileType === 'video' && !isPlay"
            >
              <img src="@/assets/icons/105.svg" alt="" />
            </div>
            <div class="deleteImg" @click="deleteFile(item.url)">
              <img src="@/assets/icons/106.svg" alt="" />
            </div>
          </div>
        </div>

script部分的代码:

javascript 复制代码
import { ref, reactive, toRefs, onMounted, watch, nextTick } from 'vue'
import Sortable from 'sortablejs'

const uploadImgItem = ref()
const imgList = ref<any>([])

//拖拽排序
const initDragSort = () => {
  nextTick(() => {
    // 选择包含所有可排序项目的容器
    const el = uploadImgItem.value

    // 确保 el 是一个有效的 DOM 元素
    if (el) {
      Sortable.create(el, {
        group: 'shared', // 设置同一组内的元素可以互相排序
        fallbackOnBody: true, // 如果需要的话,可以在 body 上进行拖拽
        swapThreshold: 0.65, // 控制元素交换的阈值
        onEnd: (/** 事件对象 */ evt: any) => {
          // 获取旧的索引和新索引
          const { oldIndex, newIndex } = evt

          // 交换位置
          const movedItem = imgList.value.splice(oldIndex, 1)[0]
          imgList.value.splice(newIndex, 0, movedItem)
          console.log(imgList.value)
        }
      })
    }
  })
}
相关推荐
vipbic3 小时前
别再把“做个H5”挂嘴边了:这个词,官方压根就没有定义过
前端
ZC跨境爬虫5 小时前
跟着 MDN 学CSS day_39:(Flexbox 弹性盒子核心机制)
前端·css·ui·html·tensorflow
小陈同学呦5 小时前
前端如何处理订单状态导航的数据竞态问题
前端·javascript
开发者每周简报5 小时前
网海三部曲·无名宗师传
javascript·人工智能
喵个咪5 小时前
GoWind Toolkit 前端代码生成|Vue3(ElementPlus/Vben)、React(AntDesign)全自动一键生成教程
前端·vue.js·react.js
qq_2518364576 小时前
SpringBoot+Vue 共享电池柜管理系统 完整实现 前后端分离项目实战 完整代码
vue.js·spring boot·后端
摆烂大大王7 小时前
玩转 OpenClaw:用 TaskFlow + Heartbeat 打造自动化工作流
前端·人工智能·自动化
zhangxingchao7 小时前
AI 大模型核心六:量化、Workflow 与 Agent、多轮 RAG
前端·人工智能·后端
梦想的颜色7 小时前
TypeScript 完全指南(上):从零开始掌握类型系统
前端·typescript
之歆7 小时前
Day01_ES6+ 专业指南:从基础到实战的现代JavaScript开发(下)
前端·javascript·es6