返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue利用draggable实现多选拖拽效果
  • 488
分享到

Vue利用draggable实现多选拖拽效果

2024-04-02 19:04:59 488人浏览 安东尼
摘要

目录前言实现思路Demo全部代码Demo实现效果前言 最近产品提出一个排序需求,希望能进行拖拽排序,我一想,Vue2插件这么多,sortable.js、draggable分分钟实现了

前言

最近产品提出一个排序需求,希望能进行拖拽排序,我一想,Vue2插件这么多,sortable.js、draggable分分钟实现了,但是还有一个需求希望能够实现多选拖拽,这个就有点麻烦,查询了许多资料,暂时没有发现能够多选的拖拽组件,如果自己写一个,既耗费时间,实现效果上必然没有draggable这种成熟轮子效果好,于是决定基于draggable做改进。

实现思路

我们知道draggable插件只要设置相同的group名字就能实现分组拖拽,如果我们渲染两个同名分组,控制第二个分组的显示与隐藏,鱼目混珠,就能实现简单的多选拖拽效果

1.通过group="task"设置两个同名分组,同时利用draggable=".card"属性,控制class名称,禁止单选

  <draggable group="task" v-model="dataList" @end="draggerEnd" class=""
        :class="show ? 'order-box-show' : 'order-box'" animation="300" draggable=".card">
        <transition-group>
          <div v-for="(item, index) in dataList" :key="index" class="box" @click="handleSelect(index)"
            :class="item.select || show ? 'card' : ''">{{ item.name }}
          </div>
        </transition-group>
      </draggable>
      <div class="position" v-show="show">
        <draggable group="task" v-model="dataList2" @end="draggerEnd" class="order-box" animation="300">
          <transition-group>
            <div v-for="(item, index) in dataList2" :key="index" class="boxs">
              <div>
                {{ item.name }}
              </div>
            </div>
          </transition-group>
        </draggable>

2.通过v-show="show"控制第二个分组的隐藏与展示,同时对数据做处理,并且在拖拽结束后,要在分组一中找到分组二拖拽过来的初始元素删掉

    const findIndex = this.dataList.findIndex((item => item.name === '选中元素展示区'))
      this.dataList.splice(findIndex, 1)

Demo全部代码

<template>
  <div>
    <div>
      <draggable group="task" v-model="dataList" @end="draggerEnd" class=""
        :class="show ? 'order-box-show' : 'order-box'" animation="300" draggable=".card">
        <transition-group>
          <div v-for="(item, index) in dataList" :key="index" class="box" @click="handleSelect(index)"
            :class="item.select || show ? 'card' : ''">{{ item.name }}
          </div>
        </transition-group>
      </draggable>
      <div class="position" v-show="show">
        <draggable group="task" v-model="dataList2" @end="draggerEnd" class="order-box" animation="300">
          <transition-group>
            <div v-for="(item, index) in dataList2" :key="index" class="boxs">
              <div>
                {{ item.name }}
              </div>
            </div>
          </transition-group>
        </draggable>
      </div>
    </div>
    <el-button style="marginLeft:50px" @click="handleStart">确认</el-button>
  </div>
</template>

<script>
import draggable from 'vuedraggable'
export default {
  components: {
    draggable
  },
  data() {
    return {
      dataList: [
      ],
      dataList2: [{ name: '选中元素展示区' }],
      show: false,
      selectArr: [],
    }
  },
  mounted() {
    for (var i = 0; i < 60; i++) {
      this.dataList.push({ name: i, select: false })
    }
  },
  methods: {
    handleSelect(index) {
      const data = JSON.parse(JSON.stringify(this.dataList))
      data[index].select = true
      this.selectArr.push({ ...data[index] })
      this.dataList = JSON.parse(JSON.stringify(data))
    },
    handleStart(e) {
      if (!this.selectArr.length) {
        return
      }
      this.show = true
      this.selectArr.forEach((item, index) => {
        const Index = this.dataList.findIndex(it => item.name === it.name)
        this.dataList.splice(Index, 1)
      })
    },
    draggerEnd(e) {
      const newIndex = e.newIndex
      this.dataList.splice(newIndex, 0, ...this.selectArr)
      const findIndex = this.dataList.findIndex((item => item.name === '选中元素展示区'))
      this.dataList.splice(findIndex, 1)
      this.show = false
    },


  }
}
</script>

<style lang="sCSS" scoped>
.order-box {
  padding: 20px 50px;
  display: flex;
  flex-wrap: wrap;

  >span {
    flex: 1;
    display: flex;
    flex-wrap: wrap;
  }

  .box {
    width: 100px;
    height: 50px;
    background: rgb(7, 174, 215);
    margin-right: 10px;
    margin-bottom: 10px;
  }

  .boxs {
    width: 100px;
    height: 50px;
    background: rgb(215, 177, 7);
    margin-right: 10px;
    margin-bottom: 10px;
  }

  .card {
    background: rgb(128, 68, 0) !important;
  }
}

.order-box-show {
  padding: 20px 50px;
  display: flex;
  flex-wrap: wrap;

  >span {
    flex: 1;
    display: flex;
    flex-wrap: wrap;
  }

  .box {
    width: 100px;
    height: 50px;
    background: rgb(7, 174, 215);
    margin-right: 10px;
    margin-bottom: 10px;
  }

  .boxs {
    width: 100px;
    height: 50px;
    background: rgb(215, 177, 7);
    margin-right: 10px;
    margin-bottom: 10px;
  }
}

.position {
  border: 1px solid red;
  position: fixed;
  top: 50%;
  left: 50%;
  transfORM: translate(-50%, -50%);
  cursor: pointer;
}
</style>

Demo实现效果

到此这篇关于Vue利用draggable实现多选拖拽效果的文章就介绍到这了,更多相关Vue draggable多选拖拽内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Vue利用draggable实现多选拖拽效果

本文链接: https://lsjlt.com/news/148092.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Vue利用draggable实现多选拖拽效果
    目录前言实现思路Demo全部代码Demo实现效果前言 最近产品提出一个排序需求,希望能进行拖拽排序,我一想,vue2插件这么多,sortable.js、draggable分分钟实现了...
    99+
    2024-04-02
  • vue-draggable实现pc端拖拽效果
    本文实例为大家分享了vue-draggable实现pc端拖拽效果的具体代码,供大家参考,具体内容如下 为了实现下面这种布局可拖拽整合调整位置 拖拽前: 拖拽后: 一、安装 npm...
    99+
    2024-04-02
  • vue-draggable怎么实现pc端拖拽效果
    本文小编为大家详细介绍“vue-draggable怎么实现pc端拖拽效果”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue-draggable怎么实现pc端拖拽效果”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧...
    99+
    2023-06-29
  • VUE使用draggable实现组件拖拽
    本文实例为大家分享了draggable组件拖拽实例,供大家参考,具体内容如下 实现步骤 1、导入draggable依赖 npm i -S vuedraggable 2、引入dragg...
    99+
    2024-04-02
  • VUE怎么使用draggable实现组件拖拽
    这篇文章主要讲解了“VUE怎么使用draggable实现组件拖拽”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“VUE怎么使用draggable实现组件拖拽”吧!实现步骤1、导入draggab...
    99+
    2023-06-29
  • vue实现弹窗拖拽效果
    本文实例为大家分享了vue实现弹窗拖拽效果的具体代码,供大家参考,具体内容如下 前言 实现拖拽其实简单来说就分为三步 一、创建一个js文件 因为本身dialog窗口不具备移动拖拽能力...
    99+
    2024-04-02
  • vue实现拖拽排序效果
    本文实例为大家分享了vue实现拖拽排序效果的具体代码,供大家参考,具体内容如下 效果预览 组件 drag.vue <template>   <Transition...
    99+
    2024-04-02
  • Vue draggable怎么实现从左到右拖拽功能
    这篇文章主要介绍了Vue draggable怎么实现从左到右拖拽功能的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue draggable怎么实现从左到右拖拽功能文章都会有所收获,下面我们...
    99+
    2023-06-29
  • vue draggable组件实现拖拽及点击无效问题的解决
    目录一、效果图二、拖拽及点击无效解决方法三、vuedraggable的使用在实现一个移动端项目的时候,根据产品需求,要实现一个既能增加删除又可以拖拽调换位置的效果,然后我使用了dra...
    99+
    2024-04-02
  • 使用纯JS实现checkbox的框选效果(鼠标拖拽多选)
    目录主要思路css 代码如下html结构如下js主要逻辑如下总结 主要思路 用一个盒子作为选区,通过定位让其固定在左上角,由于没有给定选区元素的宽高所以默认不显示,在 onmouse...
    99+
    2024-04-02
  • AndroidRecycleView实现Item拖拽效果
    基于公司产品的优化需求,其中一个需求涉及到RecycleView的拖拽,以及拖拽后item位置的持久化,目的是可以用户自定义界面偏好,并在用户下次进入本界面后,之前设置的偏好仍然有效...
    99+
    2024-04-02
  • vue怎么实现列表拖拽排序效果
    这篇文章主要介绍“vue怎么实现列表拖拽排序效果”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue怎么实现列表拖拽排序效果”文章能帮助大家解决问题。效果如下:<template>&nb...
    99+
    2023-06-29
  • 拖拽插件sortable.js实现el-table表格拖拽效果
    目录问题描述案例一 简单拖拽代码附上案例二 el-table表格拖拽效果图代码附上问题描述 Sortable.js是一款优秀的js拖拽库,因为是原生js写的,所以性能不错,也支持移动...
    99+
    2024-04-02
  • JavaScript实现简单拖拽效果
    本文实例为大家分享了JavaScript实现简单拖拽效果的具体代码,供大家参考,具体内容如下 先看实现的效果: 思路:里面用到了三个事件,鼠标按下、移动、松开事件 那么首先创建盒子...
    99+
    2024-04-02
  • JavaScript实现拖拽简单效果
    本文实例为大家分享了JavaScript实现拖拽效果的具体代码,供大家参考,具体内容如下 1.1 拖拽的基本效果 思路: 鼠标在盒子上按下时,准备移动 (事件加给物体) 鼠标移动时,...
    99+
    2024-04-02
  • JavaScript实现鼠标拖拽效果
    本文实例为大家分享了JavaScript实现鼠标拖拽效果的具体代码,供大家参考,具体内容如下 这次的效果图如下: 我认为这个实验的难点是保持盒子和鼠标的相对位置不变,通过鼠标按下和...
    99+
    2024-04-02
  • 怎么使用vue+gojs实现拖拽流程图效果
    这篇文章主要介绍“怎么使用vue+gojs实现拖拽流程图效果”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用vue+gojs实现拖拽流程图效果”文章能帮助大家解决问题。一、流程图效果二、为什么...
    99+
    2023-07-05
  • vue实现多栏布局拖拽
    本文实例为大家分享了vue实现多栏布局拖拽的具体代码,供大家参考,具体内容如下 一、目标 vue 实现多个盒子(用户根据实际场景决定盒子数量)自由拖拽,改变宽度。 二、应用场景 可自...
    99+
    2024-04-02
  • 如何使用JavaScript实现拖拽效果
    这篇文章主要介绍如何使用JavaScript实现拖拽效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!拖拽在前端开发中是很常见的功能,也是基本功之一,本文是不限制范围的拖拽也就是最简...
    99+
    2024-04-02
  • iOS开发UICollectionView实现拖拽效果
    一.介绍 iOS9提供API实现单元格排序功能,使用UICollectionView及其代理方法。iOS9之后有自带方法可以实现该效果,只需添加长按手势,实现手势方法和调用iOS9的...
    99+
    2022-05-23
    iOS UICollectionView 拖拽
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作