vue3 通用svg组件

  1. SvgIcon.vue 组件
// SvgIcon.vue
<template>
  <svg
    :class="['svg-icon', className]"
    :style="svgStyle"
    :width="size"
    :height="size"
    aria-hidden="true"
  >
    <use :href="symbolId" />
  </svg>
</template>

<script setup lang="ts">
import { computed } from 'vue'

interface Props {
  // symbol的名字
  name: string
  // 图标大小
  size?: string | number
  // 自定义类名
  className?: string
  // 颜色
  color?: string
  // 旋转角度
  rotate?: number
  // 是否旋转动画
  spin?: boolean
  // svg前缀,拼接symbolId
  prefix?: string
}

const props = withDefaults(defineProps<Props>(), {
  size: '1em',
  className: '',
  color: 'currentColor',
  rotate: 0,
  spin: false,
  prefix: '#icon-'
})

const symbolId = computed(() => props.prefix + props.name)

const svgStyle = computed(() => ({
  fill: props.color,
  transform: props.rotate ? `rotate(${props.rotate}deg)` : '',
  animation: props.spin ? 'rotating 1s linear infinite' : ''
}))
</script>

<style>
.svg-icon {
  display: inline-block;
  vertical-align: middle;
  overflow: hidden;
  fill: currentColor;
}

/* 解决svg color设置无效问题,需要修改全局的 symbol 引入样式来修改 color */
symbol {
  color: v-bind(color);
}

@keyframes rotating {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
</style>
  1. 安装插件 pnpm add -D vite-plugin-svg-icons
  2. 配置 vite
// vite.config.ts
import { createSvgIconsPlugin } from 'vite-plugin-svg-icons'
import path from 'path'

export default defineConfig({
  plugins: [
    createSvgIconsPlugin({
      iconDirs: [path.resolve(process.cwd(), 'src/assets/icons')],
      symbolId: 'icon-[dir]-[name]',
    }),
  ],
})
  1. 使用示例
<template>
  <SvgIcon name="user" size="24" color="#333" />
</template>
  1. 注意:
    设置 color 无法修改 svg 颜色问题
    通常是因为 SVG 文件本身定义了 fill 属性

  1. 移除 SVG 源文件中的固定颜色属性:
<!-- 修改前 -->
<svg>
  <path fill="#000000" d="..."/>
</svg>

<!-- 修改后 -->
<svg>
  <path d="..."/>
</svg>
  1. 或者在 SVG 源文件中使用 currentColor
<svg>
  <path fill="currentColor" d="..."/>
</svg>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值