当前位置:首页 > VUE

vue实现icon多选组件

2026-02-22 23:20:11VUE

实现思路

通过封装一个支持多选的图标选择器组件,利用 Vue 的响应式特性管理选中状态,结合图标库(如 Font Awesome、Element UI 图标)渲染可选项,并暴露选中数据供父组件使用。

核心代码实现

图标数据配置

假设使用 Element UI 的图标库,预先定义图标列表:

// iconList.js
export const iconList = [
  'el-icon-platform-eleme',
  'el-icon-delete-solid',
  'el-icon-setting',
  'el-icon-user-solid',
  // 更多图标...
];

组件模板

<template>
  <div class="icon-selector">
    <div 
      v-for="icon in icons" 
      :key="icon"
      class="icon-item"
      :class="{ 'selected': selectedIcons.includes(icon) }"
      @click="toggleIcon(icon)"
    >
      <i :class="icon"></i>
    </div>
  </div>
</template>

组件逻辑

<script>
import { iconList } from './iconList';

export default {
  props: {
    value: { type: Array, default: () => [] } // 接收父组件 v-model 绑定的数组
  },
  data() {
    return {
      icons: iconList,
      selectedIcons: [...this.value] // 初始化选中状态
    };
  },
  methods: {
    toggleIcon(icon) {
      const index = this.selectedIcons.indexOf(icon);
      if (index === -1) {
        this.selectedIcons.push(icon);
      } else {
        this.selectedIcons.splice(index, 1);
      }
      this.$emit('input', [...this.selectedIcons]); // 更新父组件绑定值
    }
  },
  watch: {
    value(newVal) {
      this.selectedIcons = [...newVal]; // 同步外部数据变化
    }
  }
};
</script>

样式增强

<style scoped>
.icon-selector {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.icon-item {
  padding: 8px;
  cursor: pointer;
  border: 1px solid #ddd;
  border-radius: 4px;
}
.icon-item:hover {
  background-color: #f5f5f5;
}
.icon-item.selected {
  border-color: #409eff;
  background-color: #ecf5ff;
}
</style>

使用示例

父组件中引入并绑定数据:

vue实现icon多选组件

<template>
  <icon-selector v-model="selectedIcons" />
  <p>已选图标:{{ selectedIcons.join(', ') }}</p>
</template>

<script>
import IconSelector from './IconSelector.vue';

export default {
  components: { IconSelector },
  data() {
    return {
      selectedIcons: []
    };
  }
};
</script>

关键点说明

  • 双向绑定:通过 v-model 实现父子组件数据同步,利用 value 属性和 input 事件。
  • 性能优化:图标较多时可考虑虚拟滚动(如 vue-virtual-scroller)。
  • 自定义图标库:替换 iconList 数据即可适配其他图标库(如 Font Awesome、Iconfont)。
  • 多选逻辑:通过数组的 includessplice 方法实现选中/取消选中。

标签: 多选组件
分享给朋友:

相关文章

uniapp组件写法

uniapp组件写法

Uniapp 组件的基本写法 Uniapp 的组件写法与 Vue 类似,支持单文件组件(.vue 文件)。一个基本的组件通常包含三个部分:<template>、<script>…

vue实现tooltips组件

vue实现tooltips组件

实现基础 Tooltip 组件 创建一个名为 Tooltip.vue 的单文件组件,包含模板、样式和逻辑: <template> <div class="tooltip-con…

vue图片实现多选

vue图片实现多选

Vue 图片多选实现方法 在 Vue 中实现图片多选功能可以通过以下几种方式完成,具体取决于项目需求和复杂度。 使用 v-model 和数组存储选中状态 通过 v-model 绑定一个数组来记录选中…

vue表格组件实现

vue表格组件实现

Vue表格组件实现 基础表格实现 使用el-table组件实现基础表格功能。安装Element UI后,引入el-table和el-table-column组件。 <template>…

vue组件实现vmodel

vue组件实现vmodel

Vue 组件实现 v-model 在 Vue 中,v-model 是双向数据绑定的语法糖,默认情况下绑定 value 属性并监听 input 事件。在自定义组件中实现 v-model 需要正确配置 p…

js 多选 实现

js 多选 实现

实现多选的 JavaScript 方法 使用复选框(Checkbox)实现多选 通过 HTML 的 checkbox 元素配合 JavaScript 实现多选功能。用户可以选择多个选项,提交时获取所有…