当前位置:首页 > VUE

vue 实现复选

2026-01-07 07:29:44VUE

Vue 实现复选功能

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

使用 v-model 绑定数组

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

vue 实现复选

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

自定义复选框组件

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

vue 实现复选

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

全选与反选功能

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

<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 CLI 或 Vite 快速初始化项目。Vue CLI 适合传统项目,Vite 更适合现代轻量级应用。安装后通过命令行工具选择所需配置(如 Rou…

vue功能实现

vue功能实现

Vue 功能实现指南 Vue.js 是一个渐进式 JavaScript 框架,广泛用于构建用户界面。以下是 Vue 功能的常见实现方法。 数据绑定 Vue 的核心功能之一是数据绑定,通过 v-mod…

vue observer实现

vue observer实现

Vue Observer 实现原理 Vue 的响应式系统核心是通过 Object.defineProperty(Vue 2)或 Proxy(Vue 3)实现的 Observer 模式。以下是关键实现细…

vue翻页实现

vue翻页实现

Vue翻页实现方法 基础分页组件实现 使用v-for和计算属性实现基础分页逻辑: <template> <div> <ul> <li…

vue 动画实现

vue 动画实现

Vue 动画实现方式 Vue 提供了多种方式实现动画效果,主要分为内置组件和第三方库集成。 使用 Vue 内置过渡组件 Vue 的 <transition> 和 <transiti…

vue 实现fadeout

vue 实现fadeout

Vue 实现淡出效果 在 Vue 中实现淡出(fade-out)效果可以通过 CSS 过渡或动画结合 Vue 的动态渲染功能完成。以下是几种常见方法: 使用 Vue 过渡(Transition)组件…