当前位置:首页 > VUE

vue实现icon多选组件

2026-02-22 23:20:11VUE

实现思路

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

vue实现icon多选组件

核心代码实现

图标数据配置

假设使用 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>

使用示例

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

<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 方法实现选中/取消选中。

vue实现icon多选组件

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

相关文章

实现vue组件

实现vue组件

Vue 组件的基本实现 Vue 组件是 Vue.js 的核心特性之一,允许将 UI 拆分为独立、可复用的模块。以下是实现 Vue 组件的几种方式: 单文件组件 (SFC) 使用 .vue 文件格式…

uniapp倒计时组件

uniapp倒计时组件

uniapp倒计时组件实现方法 使用内置组件实现 uniapp提供了<countdown>组件用于倒计时功能,支持自定义格式和样式。示例代码如下: <countdown :…

如何设计react组件

如何设计react组件

设计 React 组件的核心原则 React 组件的设计需要遵循高内聚、低耦合的原则,确保组件功能独立且易于维护。组件的设计可以分为展示组件和容器组件两类,展示组件负责 UI 渲染,容器组件负责逻辑处…

vue实现多选答题

vue实现多选答题

实现多选答题功能 在Vue中实现多选答题功能,可以通过以下方法完成: 数据准备 定义一个questions数组,每个问题包含题目和选项,选项是一个对象数组,每个选项有文本和是否被选中的状态。…

vue图片实现多选

vue图片实现多选

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

vue实现递归组件

vue实现递归组件

递归组件的实现方法 在Vue中实现递归组件主要依靠组件调用自身的能力。以下是几种常见的实现方式: 使用组件name属性 通过组件的name属性实现递归调用是最简单的方式: <template…