当前位置:首页 > VUE

vue实现上移下移插件

2026-02-09 20:34:12VUE

Vue 实现上移下移功能

实现列表项的上移和下移功能可以通过操作数组索引来完成。以下是基于 Vue 2 或 Vue 3 的实现方法。

基本实现

定义数据和方法操作数组项的位置:

<template>
  <div>
    <ul>
      <li v-for="(item, index) in items" :key="item.id">
        {{ item.name }}
        <button @click="moveUp(index)" :disabled="index === 0">上移</button>
        <button @click="moveDown(index)" :disabled="index === items.length - 1">下移</button>
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' },
        { id: 4, name: 'Item 4' },
      ]
    }
  },
  methods: {
    moveUp(index) {
      if (index > 0) {
        const temp = this.items[index];
        this.$set(this.items, index, this.items[index - 1]);
        this.$set(this.items, index - 1, temp);
      }
    },
    moveDown(index) {
      if (index < this.items.length - 1) {
        const temp = this.items[index];
        this.$set(this.items, index, this.items[index + 1]);
        this.$set(this.items, index + 1, temp);
      }
    }
  }
}
</script>

使用 Vue 3 Composition API

Vue 3 中可以使用 refreactive 实现类似功能:

<template>
  <div>
    <ul>
      <li v-for="(item, index) in items" :key="item.id">
        {{ item.name }}
        <button @click="moveUp(index)" :disabled="index === 0">上移</button>
        <button @click="moveDown(index)" :disabled="index === items.length - 1">下移</button>
      </li>
    </ul>
  </div>
</template>

<script>
import { ref } from 'vue';

export default {
  setup() {
    const items = ref([
      { id: 1, name: 'Item 1' },
      { id: 2, name: 'Item 2' },
      { id: 3, name: 'Item 3' },
      { id: 4, name: 'Item 4' },
    ]);

    const moveUp = (index) => {
      if (index > 0) {
        [items.value[index], items.value[index - 1]] = [items.value[index - 1], items.value[index]];
      }
    };

    const moveDown = (index) => {
      if (index < items.value.length - 1) {
        [items.value[index], items.value[index + 1]] = [items.value[index + 1], items.value[index]];
      }
    };

    return { items, moveUp, moveDown };
  }
}
</script>

封装为可复用组件

可以将上移下移功能封装为独立组件:

<template>
  <div>
    <slot :items="items" :moveUp="moveUp" :moveDown="moveDown"></slot>
  </div>
</template>

<script>
export default {
  props: {
    initialItems: {
      type: Array,
      required: true
    }
  },
  data() {
    return {
      items: [...this.initialItems]
    }
  },
  methods: {
    moveUp(index) {
      if (index > 0) {
        [this.items[index], this.items[index - 1]] = [this.items[index - 1], this.items[index]];
      }
    },
    moveDown(index) {
      if (index < this.items.length - 1) {
        [this.items[index], this.items[index + 1]] = [this.items[index + 1], this.items[index]];
      }
    }
  }
}
</script>

使用方式:

<template>
  <MoveableList :initial-items="items">
    <template #default="{ items, moveUp, moveDown }">
      <ul>
        <li v-for="(item, index) in items" :key="item.id">
          {{ item.name }}
          <button @click="moveUp(index)" :disabled="index === 0">上移</button>
          <button @click="moveDown(index)" :disabled="index === items.length - 1">下移</button>
        </li>
      </ul>
    </template>
  </MoveableList>
</template>

动画效果

添加过渡动画提升用户体验:

vue实现上移下移插件

<template>
  <div>
    <transition-group name="list" tag="ul">
      <li v-for="(item, index) in items" :key="item.id">
        {{ item.name }}
        <button @click="moveUp(index)" :disabled="index === 0">上移</button>
        <button @click="moveDown(index)" :disabled="index === items.length - 1">下移</button>
      </li>
    </transition-group>
  </div>
</template>

<style>
.list-move {
  transition: transform 0.5s;
}
</style>

标签: 插件vue
分享给朋友:

相关文章

vue实现预览

vue实现预览

Vue实现文件预览的方法 使用Vue实现文件预览功能可以通过多种方式完成,具体取决于文件类型(图片、PDF、视频等)。以下是几种常见文件类型的实现方案。 图片预览 通过<input type=…

vue如何实现冒泡

vue如何实现冒泡

Vue 实现冒泡排序 在 Vue 中实现冒泡排序,可以通过数据绑定和响应式特性动态展示排序过程。以下是一个完整的实现示例,包含代码和详细说明。 数据准备 在 Vue 的 data 中定义一个数组作为…

vue 实现排序

vue 实现排序

Vue 实现排序的方法 使用计算属性实现排序 通过计算属性对数组进行排序,可以保持原始数据不变。示例代码展示了如何对列表按名称升序排序: <template> <div>…

vue实现筛选

vue实现筛选

实现筛选功能的基本思路 在Vue中实现筛选功能通常需要结合数据绑定、计算属性和方法。筛选的核心逻辑是根据用户输入的条件过滤原始数据列表,并动态更新显示结果。 数据准备 定义一个数组存储原始数据,另一…

vue实现甘特图

vue实现甘特图

使用 Vue 实现甘特图 基于开源库(如 vue-ganttastic) 安装依赖库: npm install vue-ganttastic 示例代码: <template> &l…

vue实现treetable

vue实现treetable

Vue实现TreeTable的方法 使用第三方组件库(如Element UI) Element UI的el-table组件支持树形表格展示,通过设置row-key和tree-props属性即可实现。…