vue项目使用svg图标

下面是在 Vue 3 项目中完整引入和使用 vite-plugin-svg-icons 的步骤

1、安装插件

复制代码
npm install vite-plugin-svg-icons -D
# 或
yarn add vite-plugin-svg-icons -D
# 或
pnpm add vite-plugin-svg-icons -D

2、配置 Vite

vite.config.tsvite.config.js 中配置:

复制代码
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import { createSvgIconsPlugin } from 'vite-plugin-svg-icons'
import path from 'path'

export default defineConfig({
  plugins: [
    vue(),
    createSvgIconsPlugin({
      // 指定需要缓存的图标文件夹
      iconDirs: [path.resolve(process.cwd(), 'src/assets/svg')],
      // 指定symbolId格式
      symbolId: 'icon-[name]',
      
      // 可选配置
      svgoOptions: {
        plugins: [
          { name: 'removeAttrs', params: { attrs: ['fill'] } } // 移除svg默认颜色
        ]
      }
    })
  ]
})

3. 创建 SVG 组件

复制代码
<script setup>
import { computed } from 'vue'

const props = defineProps({
  name: {
    type: String,
    required: true,
  },
  className: {
    type: String,
    default: '',
  },
  size: {
    type: [Number, String],
    default: 15,
  },
  circle: {
    type: Boolean,
    default: false,
  },
  color: String,
  defaultImg: String,
})
const style = computed(() => {
  const size = typeof props.size === 'string' ? props.size : `${props.size}px`
  return {
    width: size,
    height: size,
    borderRadius: props.circle ? '50%' : null,
    color: props.color,
  }
})
const symbolId = computed(() => `#icon-${props.name}`)
</script>
<template>
  <svg aria-hidden="true" class="svg-icon" :class="className" :style="style">
    <use :xlink:href="symbolId" />
  </svg>
</template>
<style scoped>
.svg-icon {
  /* width: 30px;
  height: 30px; */
  display: inline-block;
  vertical-align: -2px;
  fill: currentColor;
}
</style>

4. 全局注册组件

main.js 中:

复制代码
import { createApp } from 'vue'
import App from './App.vue'
import 'virtual:svg-icons-register' // 引入注册脚本
import SvgIcon from '@/components/SvgIcon.vue' // 引入组件

const app = createApp(App)

// 全局注册svg组件
app.component('SvgIcon', SvgIcon)

app.mount('#app')

5. 使用图标

  1. 将 SVG 文件放入 src/assets/svg 目录

  2. 在组件中使用:

    html 复制代码
    <div class="img-list" v-for="(item, index) in iconlist" :key="index" @click="itemClick(item)">
    <div class="default-img">
     <!-- 在组件中使用 -->
       <SvgIcon :name="item.iconname" size="30" class="svg-icon" />
    </div>
    </div>
    const list = ref([
      {
        iconname: 'float-robot',
        id: 1
      },
      {
        iconname: 'float-wx',
        id: 2
      },
      {
        iconname: 'float-tell',
        id: 3
      },
      {
        iconname: 'float-qq',
        id: 4
      },
      {
        iconname: 'float-message-board',
        id: 5
      }
    ])
    <style scoped lang="scss">
    .img-list{
      padding: 20px;
      background: #fff;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      justify-items: center;
      height: 330px;
      cursor: pointer;
      box-shadow: 0px 0px 14px 0px rgba(0, 0, 0, 0.12);
      border-radius: 34px;
      box-sizing: border-box;
        &:hover {
          .default-img {
            .svg-icon {
              color: #005fff; // 默认颜色
              fill: currentColor; // 继承color颜色
              transition: color 0.3s ease; // 添加过渡效果
            }
          }
        }
    }
    </style>

    最后看效果:鼠标经过svg图标变蓝色

相关推荐
谷哥的小弟11 小时前
HTML5新手练习项目—个人记账本(附源码)
前端·源码·html5·项目
GISer_Jing11 小时前
2025年FE_Jinger的年度总结、经验分享与展望
前端·经验分享·面试·前端框架·aigc
.try-11 小时前
css直线中间小三角
前端·css·html
Dreamcatcher_AC11 小时前
Node.js留言板开发全流程解析
前端·javascript·mysql·node.js·express
鹏程十八少11 小时前
Android 一套代码适配车机/手机横竖屏?看我如何用搞定小米、比亚迪、蔚来、理想、多品牌架构设计
android·前端·面试
持续升级打怪中11 小时前
从前端到大模型:我的AI转型之路与实战思考
前端·人工智能
LYFlied11 小时前
【性能优化】图片渲染性能优化全流程方案详解
前端·性能优化
『六哥』11 小时前
零基础搭建完成完整的前后端分离项目的准备工作
前端·后端·项目开发
沛沛老爹11 小时前
Web开发者实战AI Agent:基于Dify实现OpenAI Deep Research智能体
前端·人工智能·gpt·agent·rag·web转型
一入程序无退路11 小时前
vue中序号不能按排序显示
javascript·vue.js·elementui