当前位置:首页 > 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 滑动组件实现方法 使用swiper组件 uniapp内置的swiper组件可以实现滑动效果,适用于轮播图或页面切换场景。 示例代码: <swiper :indicator-d…

react如何刷新组件

react如何刷新组件

刷新 React 组件的常见方法 使用状态更新触发重新渲染 通过修改组件的状态(state),React 会自动触发重新渲染。例如: const [count, setCount] = useSta…

vue 实现弹窗组件

vue 实现弹窗组件

Vue 弹窗组件实现 基础弹窗组件结构 创建一个名为Modal.vue的文件,定义弹窗的基础结构和样式: <template> <div class="modal-mask"…

vue实现高阶组件

vue实现高阶组件

Vue 高阶组件实现方法 高阶组件(HOC)是一种复用组件逻辑的模式,通过函数包裹组件并返回新组件实现。Vue 中可通过以下方式实现: 使用 render 函数 通过函数接收组件选项并返回新组件选项…

vue实现列表组件

vue实现列表组件

Vue 列表组件实现方法 基础列表渲染 使用 v-for 指令渲染数组数据,需配合 :key 提升性能: <template> <ul> <li v-for…

vue 实现树组件

vue 实现树组件

Vue 树形组件实现 基础树形结构实现 使用递归组件实现树形结构,核心是通过组件自身调用自身渲染嵌套数据。 <template> <ul> <li v-fo…