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)
        }
      })
    }
  })
}
相关推荐
讨厌下雨的天空5 分钟前
缓冲区io
linux·服务器·前端
xhxxx39 分钟前
《深入理解 JavaScript 对象:属性命名、访问与遍历的那些细节》
前端·javascript
BBB努力学习程序设计39 分钟前
Web App开发基础知识:从零构建现代化Web应用
前端·html
BBB努力学习程序设计41 分钟前
使用Bootstrap框架搭建简单页面:快速构建现代化网站
前端·html
西洼工作室41 分钟前
CSS响应式布局全攻略
前端·css·响应式布局·栅格系统
用户938169125536043 分钟前
VUE3项目配置
前端
mm-q29152227291 小时前
云原生开发实战:从入门到精通 Vue3、Vite、Pinia、Axios 与 HTML、JavaScript、CSS 项目开发
javascript·云原生·html
MegatronKing1 小时前
一个有意思的问题引起了我的反思
前端·后端·测试
JohnYan1 小时前
Bun技术评估 - 30 SSE支持
javascript·后端·bun
鹤归时起雾.1 小时前
CSS属性继承与元素隐藏全解析
前端·css