当前位置:首页 > VUE

vue实现li多选

2026-01-15 22:51:42VUE

Vue 实现列表多选功能

在 Vue 中实现列表(<li>)的多选功能可以通过多种方式完成。以下是几种常见的实现方法:

使用 v-model 绑定数组

通过 v-model 绑定一个数组来存储选中的项,适用于复选框场景。

<template>
  <ul>
    <li v-for="item in items" :key="item.id">
      <input 
        type="checkbox" 
        :value="item.id" 
        v-model="selectedItems"
      />
      {{ item.name }}
    </li>
  </ul>
</template>

<script>
export default {
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' }
      ],
      selectedItems: []
    };
  }
};
</script>

使用点击事件切换选中状态

通过点击事件动态切换选中状态,适用于无复选框的场景。

<template>
  <ul>
    <li 
      v-for="item in items" 
      :key="item.id"
      :class="{ 'selected': selectedItems.includes(item.id) }"
      @click="toggleItem(item.id)"
    >
      {{ item.name }}
    </li>
  </ul>
</template>

<script>
export default {
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' }
      ],
      selectedItems: []
    };
  },
  methods: {
    toggleItem(id) {
      if (this.selectedItems.includes(id)) {
        this.selectedItems = this.selectedItems.filter(item => item !== id);
      } else {
        this.selectedItems.push(id);
      }
    }
  }
};
</script>

<style>
.selected {
  background-color: #f0f0f0;
}
</style>

支持 Ctrl/Shift 键多选

通过监听键盘事件实现类似桌面应用的多选行为。

<template>
  <ul @click="handleLiClick">
    <li 
      v-for="item in items" 
      :key="item.id"
      :class="{ 'selected': selectedItems.includes(item.id) }"
      :data-id="item.id"
    >
      {{ item.name }}
    </li>
  </ul>
</template>

<script>
export default {
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' }
      ],
      selectedItems: []
    };
  },
  methods: {
    handleLiClick(event) {
      const id = parseInt(event.target.dataset.id);
      if (event.ctrlKey || event.metaKey) {
        // Ctrl/Cmd 键多选
        this.toggleItem(id);
      } else {
        // 普通单选
        this.selectedItems = [id];
      }
    },
    toggleItem(id) {
      if (this.selectedItems.includes(id)) {
        this.selectedItems = this.selectedItems.filter(item => item !== id);
      } else {
        this.selectedItems.push(id);
      }
    }
  }
};
</script>

使用第三方库

对于更复杂的需求,可以考虑使用第三方库如 vue-draggablev-select 等。

npm install vue-draggable
<template>
  <draggable 
    v-model="items" 
    @start="drag=true" 
    @end="drag=false"
  >
    <li 
      v-for="item in items" 
      :key="item.id"
      :class="{ 'selected': selectedItems.includes(item.id) }"
      @click="toggleItem(item.id)"
    >
      {{ item.name }}
    </li>
  </draggable>
</template>

<script>
import draggable from 'vuedraggable';

export default {
  components: { draggable },
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' }
      ],
      selectedItems: []
    };
  },
  methods: {
    toggleItem(id) {
      if (this.selectedItems.includes(id)) {
        this.selectedItems = this.selectedItems.filter(item => item !== id);
      } else {
        this.selectedItems.push(id);
      }
    }
  }
};
</script>

以上方法可以根据具体需求选择或组合使用,实现灵活的多选功能。

vue实现li多选

标签: 多选vue
分享给朋友:

相关文章

项目基于vue实现

项目基于vue实现

基于Vue实现项目的关键方法 搭建基础环境 安装Node.js和npm/yarn,确保开发环境具备运行Vue的能力。通过Vue CLI快速初始化项目结构,选择所需配置(如Babel、Router、Vu…

vue实现裁剪头像

vue实现裁剪头像

Vue 实现头像裁剪功能 实现头像裁剪功能通常需要结合第三方库如 cropperjs 或 vue-cropper。以下是两种常见实现方式: 使用 vue-cropper 库 安装依赖: np…

vue实现压缩上传文件

vue实现压缩上传文件

压缩上传文件的实现方法 在Vue中实现文件压缩和上传功能,可以通过以下步骤完成。该方法结合了前端文件压缩库和HTTP请求,确保文件在上传前被有效压缩。 安装必要的依赖 需要使用compressorj…

vue实现上移下移插件

vue实现上移下移插件

实现上移下移功能的 Vue 插件 在 Vue 中实现列表项的上移和下移功能,可以通过自定义指令或组件封装的方式完成。以下是两种常见实现方式: 基于数组操作的通用方法 通过操作数组索引实现元素位置交换…

vue实现菜单栏锚点

vue实现菜单栏锚点

实现锚点菜单的基本思路 在Vue中实现菜单栏锚点功能,主要涉及两个方面:创建可跳转的锚点位置,以及菜单项的点击滚动控制。通过监听滚动事件可以高亮当前可见区域的对应菜单项。 创建页面锚点位置 在需要跳…

vue实现生成二维码

vue实现生成二维码

使用qrcode.vue库生成二维码 安装qrcode.vue库: npm install qrcode.vue --save 在Vue组件中使用: <template> <…