当前位置:首页 > VUE

vue实现上移下移插件

2026-02-09 20:34:12VUE

Vue 实现上移下移功能

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

基本实现

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

vue实现上移下移插件

<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>

封装为可复用组件

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

vue实现上移下移插件

<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>

动画效果

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

<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 的“查看更多”功能 数据截取与显示控制 通过 v-if 或 v-show 控制内容的显示与隐藏。初始状态下只显示部分内容,点击“查看更多”后展开完整内容。 <template&…

vue实现方法

vue实现方法

Vue 实现方法 Vue 是一种流行的前端框架,用于构建用户界面和单页应用。以下是几种常见的 Vue 实现方法: 创建 Vue 实例 通过 new Vue() 创建一个 Vue 实例,传入配置对象,…

computed vue 实现

computed vue 实现

computed 在 Vue 中的基本用法 Vue 的 computed 属性用于声明依赖于其他数据的计算属性。当依赖的数据变化时,计算属性会自动重新计算并缓存结果。 export defau…

vue实现切换

vue实现切换

Vue 实现切换功能的方法 在 Vue 中实现切换功能可以通过多种方式实现,以下是一些常见的方法: 使用 v-if 和 v-else 指令 通过条件渲染实现切换功能,适用于简单的显示/隐藏场景。…

vue 实现后退

vue 实现后退

实现后退功能的方法 在Vue中实现后退功能通常需要结合浏览器历史记录API或Vue Router的导航方法。以下是几种常见的实现方式: 使用Vue Router的go方法 this.$rout…

vue实现datalist

vue实现datalist

使用 Vue 实现 HTML5 的 datalist 功能 HTML5 的 <datalist> 元素提供了一种自动完成输入框的功能,允许用户在输入时从预定义的选项列表中选择。以下是几种在…