vue移动端实现拖拽排序

先看需求: 我们要实现的是长按右边按钮拖拽排序  而不是选中这条数据就可以拖拽,因此vuedraggable 组件在这里是不合适的 

1.首先需要用到一个SortableJS

官网: http://www.sortablejs.com/index.html

这里我们直接下载就可以了

npm install sortablejs --save

 2. 然后在官网的案例中有个 handle的案例 是点中哪一条数据里的按钮才可以实现拖拽

 这样子点中前面的图标才可以拖拽

我们就用这个吧

3.引入 组件

<script>
import Sortable from "sortablejs";
export default {
data(){
return{

}
</script>

4.在遍历的数据上使用 

      <div class="list_item"
        v-for="(item, index) in bingList"
        :key="index"
      >
        <div class="remove">
          <van-icon
          @click="removeFn()"
            class="remove_icon"
            name="delete-o"
            size="30"
            color="#eb5757"
          />
        </div>
        <div class="name">
          <div>{{ item.name }}</div>
          <div>包含{{ item.num }}人</div>
        </div>
        <div class="sort">
            <-- !这里是排序的图标 -->
          <van-icon name="wap-nav" size="30" color="#a0a6b1" />
        </div>
      </div>
    </div>

5.然后我们在mounted里使用这个方法

 mounted() {
    //这里是获取到数组的元素
    var el = document.getElementById("list_item");
    new Sortable(el, {
      handle: ".sort", // handle's class
      animation: 150,
      onEnd:(evt)=>{
       //拖拽动作结束后执行
        this.bingList.splice(evt.newIndex, 0, this.bingList.splice(evt.oldIndex, 1)[0])
        var newArray = this.bingList.slice(0)
        this.bingList = []
        this.$nextTick(function () {
            this.bingList = newArray
            console.log(this.bingList);
          })
      }
    });

   
  },

弄好之后 拖拽可能会超出屏幕  css里加入 overflow: hidden;就好了

备注:具体的配置项还要看官方文档 就不一一解释了 

点个赞吧

  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
手风琴动画是指在一组元素中,其中一个元素被展开时,其他元素同时被收缩,形成一个类似于手风琴的效果。在 Vue 移动端开发中,可以使用 transition 动画来实现手风琴效果。 首先,在 HTML 中定义一组需要展开和收缩的元素,可以使用 v-for 指令来动态渲染元素,并绑定一个 active 变量表示当前展开元素的索引: ``` <div class="accordion"> <div v-for="(item, index) in items" :key="index" :class="{ active: index === active }"> <div class="title" @click="toggle(index)"> {{ item.title }} </div> <div class="content"> {{ item.content }} </div> </div> </div> ``` 其中,toggle 方法用于切换展开和收缩状态: ``` methods: { toggle(index) { this.active = index === this.active ? -1 : index; } } ``` 接下来,在 CSS 中定义手风琴动画的样式,使用 transform 属性实现元素的展开和收缩: ``` .accordion { .title { cursor: pointer; } .content { overflow: hidden; transition: height 0.3s ease-out; &.active { height: auto; transition: height 0.3s ease-in; } } } ``` 其中,active 类用于控制元素的展开和收缩状态,当元素被激活时,添加 active 类,并将高度设置为 auto,实现元素的展开效果;当元素被取消激活时,移除 active 类,并将高度设置为 0,实现元素的收缩效果。 最后,在 Vue 中使用 transition 组件包裹元素,实现动画效果: ``` <transition name="accordion"> <div v-for="(item, index) in items" :key="index" :class="{ active: index === active }"> <div class="title" @click="toggle(index)"> {{ item.title }} </div> <div class="content"> {{ item.content }} </div> </div> </transition> ``` 其中,name 属性用于指定动画的名称,可以在 CSS 中定义对应的动画样式。 这样就完成了手风琴动画的实现

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值