1、创建src/icons/svg目录,将自己的图标放入此文件夹内。
2、下载插件
npm i vite-plugin-svg-icons -D
3、vite.config.ts 中的配置插件
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import path from "path";
import { createSvgIconsPlugin } from 'vite-plugin-svg-icons'
// https://vitejs.dev/config/
export default defineConfig({
plugins: [
vue(),
createSvgIconsPlugin({
// 指定需要缓存的图标文件夹
iconDirs: [path.resolve(process.cwd(), 'src/icons')],
// 指定symbolId格式
symbolId: 'icon-[dir]-[name]',
}),
],
})
4、main.ts
import 'virtual:svg-icons-register'
5、 创建src/components/svg,封装svg组件
<template>
<div
v-if="External"
:style="styleExternalIcon"
class="svg-external-icon svg-icon"
v-bind="$attrs"
/>
<svg v-else :class="svgClass" aria-hidden="true" v-bind="$attrs">
<use :xlink:href="symbolId" />
</svg>
</template>
<script>
// doc: https://panjiachen.github.io/vue-element-admin-site/feature/component/svg-icon.html#usage
import { isExternal } from '@/utils/validate'
import { defineComponent, reactive, ref, computed } from 'vue'
export default defineComponent({
name: 'SvgIcon',
props: {
iconClass: {
type: String,
required: true
},
className: {
type: String,
default: ''
}
},
setup (props) {
const External = computed(() => {
return isExternal(props.iconClass)
})
const symbolId = computed(() => {
return `#icon-${props.iconClass}`
})
const svgClass = computed(() => {
if (props.className) {
return 'svg-icon ' + props.className
} else {
return 'svg-icon'
}
})
const styleExternalIcon = computed(() => {
return {
mask: `url(${props.iconClass}) no-repeat 50% 50%`,
'-webkit-mask': `url(${props.iconClass}) no-repeat 50% 50%`
}
})
return {
External,
symbolId,
svgClass,
styleExternalIcon,
}
}
})
</script>
<style scoped>
.svg-icon {
width: 1.4em;
height: 1.4em;
margin: 0 0 0 2px;
vertical-align: -0.1em;
fill: currentColor;
overflow: hidden;
}
.svg-external-icon {
background-color: currentColor;
mask-size: cover !important;
display: inline-block;
}
</style>
其中utils/validate.ts
/**
* Created by PanJiaChen on 16/11/18.
*/
/**
* @param {string} path
* @returns {Boolean}
*/
export function isExternal(path: string) {
const isExternal = /^(https?:|http?:|mailto:|tel:)/.test(path);
return isExternal;
}
6、全局注册mian.ts
import 'virtual:svg-icons-register'
import SvgIcon from "@/components/svg/index.vue";
const app = createApp(App)
app.use(store)
.use(router)
.use(ElementPlus)
.component('svg-icon', SvgIcon)
.mount("#app");
7、页面使用
在所需页面中也需要引入svgIcon组件
<SvgIcon icon-class="yonghu"/>