当前位置:首页 > 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 提供了多种方式实现动画效果,主要通过内置组件和第三方库支持。 使用 Vue 内置过渡组件 Vue 的 transition 和 transition-group 组件可…

vue实现标签

vue实现标签

Vue 实现标签的方法 在 Vue 中实现标签功能可以通过多种方式完成,以下是几种常见的方法: 使用动态组件 动态组件可以根据不同的条件渲染不同的标签内容。通过 :is 属性动态绑定组件名,实现标签…

vue实现表白

vue实现表白

Vue 实现表白页面 使用 Vue 可以快速创建一个动态、交互式的表白页面。以下是一个简单的实现方案: 基础结构 创建一个 Vue 项目或单文件组件,包含以下核心部分: <template&…

vue实现webapp

vue实现webapp

Vue 实现 WebApp 的基本步骤 环境准备 确保已安装 Node.js 和 npm/yarn。通过 Vue CLI 或 Vite 创建项目: npm install -g @vue/cli v…

vue底层实现

vue底层实现

Vue.js 的底层实现原理 Vue.js 是一个渐进式 JavaScript 框架,其核心实现主要包括响应式系统、虚拟 DOM、模板编译和组件化机制。以下是其关键实现细节: 响应式系统 Vue 2…

vue实现flbook

vue实现flbook

Vue 实现类似 Flbook 的翻页效果 要实现类似 Flbook 的翻页效果,可以使用 Vue 结合 CSS 动画和 JavaScript 事件处理。以下是实现方法: 安装依赖 需要安装 vue…