当前位置:首页 > VUE

vue 实现复选

2026-01-07 07:29:44VUE

Vue 实现复选功能

在 Vue 中实现复选功能可以通过多种方式完成,以下是常见的几种方法:

使用 v-model 绑定数组

通过 v-model 绑定一个数组,可以自动收集用户选择的复选框值。

<template>
  <div>
    <label v-for="option in options" :key="option.value">
      <input 
        type="checkbox" 
        v-model="selectedOptions" 
        :value="option.value"
      >
      {{ option.label }}
    </label>
    <p>Selected: {{ selectedOptions }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      options: [
        { value: 'apple', label: 'Apple' },
        { value: 'banana', label: 'Banana' },
        { value: 'orange', label: 'Orange' }
      ],
      selectedOptions: []
    };
  }
};
</script>

自定义复选框组件

如果需要更复杂的逻辑或样式,可以封装一个自定义复选框组件。

<template>
  <div>
    <checkbox-group v-model="selectedItems">
      <checkbox-item value="item1">Item 1</checkbox-item>
      <checkbox-item value="item2">Item 2</checkbox-item>
      <checkbox-item value="item3">Item 3</checkbox-item>
    </checkbox-group>
    <p>Selected: {{ selectedItems }}</p>
  </div>
</template>

<script>
import CheckboxGroup from './CheckboxGroup.vue';
import CheckboxItem from './CheckboxItem.vue';

export default {
  components: { CheckboxGroup, CheckboxItem },
  data() {
    return {
      selectedItems: []
    };
  }
};
</script>

动态生成复选框

根据数据动态生成复选框,适合选项数量不固定的场景。

<template>
  <div>
    <div v-for="item in dynamicItems" :key="item.id">
      <input 
        type="checkbox" 
        v-model="checkedItems" 
        :value="item.id"
      >
      {{ item.name }}
    </div>
    <p>Checked IDs: {{ checkedItems }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      dynamicItems: [
        { id: 1, name: 'Option A' },
        { id: 2, name: 'Option B' },
        { id: 3, name: 'Option C' }
      ],
      checkedItems: []
    };
  }
};
</script>

全选与反选功能

实现全选或反选逻辑,可以通过计算属性或方法完成。

vue 实现复选

<template>
  <div>
    <label>
      <input type="checkbox" v-model="selectAll"> Select All
    </label>
    <div v-for="item in items" :key="item.id">
      <input 
        type="checkbox" 
        v-model="selectedIds" 
        :value="item.id"
      >
      {{ item.name }}
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' }
      ],
      selectedIds: []
    };
  },
  computed: {
    selectAll: {
      get() {
        return this.selectedIds.length === this.items.length;
      },
      set(value) {
        this.selectedIds = value ? this.items.map(item => item.id) : [];
      }
    }
  }
};
</script>

注意事项

  • 确保 v-model 绑定的数组初始化为空数组,否则可能导致绑定失效。
  • 动态生成复选框时,为每个选项设置唯一的 key 以优化渲染性能。
  • 使用自定义组件时,注意父子组件之间的数据传递和事件通信。

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

相关文章

vue实现冰墩墩

vue实现冰墩墩

使用 Vue 实现冰墩墩动画 通过 Vue 的动画特性和 SVG 技术,可以动态渲染冰墩墩的形象。以下是具体实现方法: 准备 SVG 素材 冰墩墩的形象通常由多个 SVG 路径组成,包括身体轮廓、面…

vue 实现

vue 实现

Vue 实现的基本步骤 安装 Vue.js 可以通过 npm 或 CDN 引入。使用 npm 安装适合大型项目,CDN 适合快速原型开发。 npm install vue 在 HTML 文件中引入…

vue slot实现

vue slot实现

vue slot 的实现方法 在 Vue 中,slot 是一种内容分发机制,允许父组件向子组件传递模板内容。以下是几种常见的 slot 实现方式: 默认 slot 默认 slot 是最基础的 slo…

vue vnode实现

vue vnode实现

Vue VNode 实现原理 VNode(Virtual Node)是 Vue 的核心概念之一,用于描述真实 DOM 的轻量级虚拟表示。VNode 的实现涉及以下关键点: VNode 的基本结构 V…

轮播vue实现

轮播vue实现

使用 Vue 实现轮播功能 基础轮播实现 安装依赖(如使用 Swiper): npm install swiper vue-awesome-swiper 组件代码示例: <templ…

vue实现tabbar

vue实现tabbar

Vue 实现 TabBar 的方法 使用 Vue Router 实现基础 TabBar 安装 Vue Router 依赖: npm install vue-router 创建路由配置文件(route…