npm install svg-sprite-loader --save-dev
vue-cli项目默认状况下会使用 url-loader 对svg进行处理,会将它放在/img 目录下,因此这时候咱们引入svg-sprite-loader 会引起一些冲突。vue
//默认`vue-cli` 对svg作的处理,正则匹配后缀名为.svg的文件,匹配成功以后使用 url-loader 进行处理。 { test: /\.(png|jpe?g|gif|svg)(\?.*)?$/, loader: 'url-loader', options: { limit: 10000, name: utils.assetsPath('img/[name].[hash:7].[ext]') } }
解决方案:使用 webpack 的 exclude和 include,让svg-sprite-loader只处理你指定文件夹下面的 svg,url-loaer只处理除此文件夹以外的因此 svg,这样就完美解决了以前冲突的问题。对配置文件进行如下修改:webpack
{ test: /\.svg$/, loader: 'svg-sprite-loader', include:[resolve('src/assets/icons')], options: { symbolId: 'icon-[name]', name: utils.assetsPath('img/[name].[hash:7].[ext]') } }, { test: /\.(png|jpe?g|gif|svg)(\?.*)?$/, loader: 'url-loader', exclude:[resolve('src/assets/icons')], options: { limit: 10000, name: utils.assetsPath('img/[name].[hash:7].[ext]') } },
创建vue-cli项目,在src/components下创建icon-svg.vue文件。web
<template> <svg class="svg-icon" aria-hidden="true"> <use :xlink:href="iconName"></use> </svg> </template> <script> export default { name: 'icon-svg', props: { iconClass: { type: String, required: true } }, computed: { iconName() { return `#icon-${this.iconClass}` // 与配置文件的配置格式一致 } } } </script> <style> .svg-icon { width: 50px; height: 50px; vertical-align: -0.15em; fill: currentColor; overflow: hidden; } </style>
在入口文件全局注册组件正则表达式
//引入svg组件 import IconSvg from '@/components/icon-svg' //全局注册icon-svg Vue.component('icon-svg', IconSvg)
操做完成以后就能够在vue文件中使用svg图标了:vue-cli
import '@/assets/icons/attach_excel.svg'; //引入图标 直接使用 <svg><use xlink:href="#icon-attach_excel"/></svg> 全局组件形式使用 <icon-svg iconClass="attach_excel"></icon-svg>
以后咱们就要使用到 webpack 的 require.context:npm
require.context("./test", false, /.test.js$/); 这行代码就会去 test 文件夹(不包含子目录)下面的找全部文件名以 .test.js 结尾的文件能被 require 的文件。 即咱们能够经过正则匹配引入相应的文件模块。
require.context有三个参数:segmentfault
接下来能够在入口文件这样写,来自动引入 @/src/icons 下面全部的图标:svg
const requireAll = requireContext => requireContext.keys().map(requireContext) const req = require.context('@/assets/icons', true, /\.svg$/) requireAll(req)
vue文件直接使用:ui
<icon-svg iconClass="attach_excel"></icon-svg>