项目结构
1、webpack.base.conf.js配置loader
npm i svg-sprite-loader -D
{ test: /.(png|jpe?g|gif|svg)(?.*)?$/, loader: 'url-loader', exclude: [resolve('src/svgicons')], options: { limit: 10000, name: utils.assetsPath('img/[name].[hash:7].[ext]') } }, { test: /.svg$/, loader: 'svg-sprite-loader', include: [resolve('src/svgicons')], options: { symbolId: 'icon-[name]' } }
2、封装组件
<template> <svg class="svg-icon" aria-hidden="true"> <use :xlink:href="'#icon-'+iconName"/> </svg> </template> <script> export default { props: { iconName: { type: String, required: true } } } </script> <style scoped> .svg-icon { 1em; height: 1em; vertical-align: -0.15em; fill: currentColor !important; overflow: hidden; } </style>
3、引入svg
import Vue from 'vue' import svgicon from '../components/svgicon' Vue.component("svgicon", svgicon); const requireAll = requireContext => requireContext.keys().map(requireContext); const req = require.context('.', false, /.svg$/); requireAll(req);
4、main.js
import "./svgicons"
5、使用
<svgicon style="color: red;font-size: 50px" iconName="all"></svgicon>