github demo: github地址 若是对您有用,请顺手给个star...html
本文主要以vue-cli3
搭建的项目为例,来聊一下如何在项目中更优雅的使用svg
。vue
众所周知,vue-cli3
已经推出很长一段时间了,你们能够感觉一下vue-cli3
带来的零配置体验。But,也相应带来了一些弊端,就是若是须要修改默认的loader
时,会比较麻烦。node
好了,上正题,建议看此文章以前先去看一下张鑫旭大神的将来必热:SVG Sprite技术介绍,那么咱们接下来主要使用的就是上文中提到的svg
的 use
,先上一张vue-cli3
搭建的项目的目录,能够看到根目录下只保留了public/
以及src/
,能够说很是干净,你们能够本身建立一个。webpack
src/components/
下建立SvgIcon
组件<template>
<svg :class="svgClass" aria-hidden="true">
<use :xlink:href="iconName"/>
</svg>
</template>
<script>
export default {
name: 'SvgIcon',
props: {
iconClass: {
type: String,
required: true,
},
className: {
type: String,
default: '',
},
},
computed: {
iconName () {
return `#icon-${this.iconClass}`
},
svgClass () {
if (this.className) {
return 'svg-icon ' + this.className
} else {
return 'svg-icon'
}
},
},
}
</script>
<style scoped>
.svg-icon {
width: 1em;
height: 1em;
vertical-align: -0.15em;
fill: currentColor;
overflow: hidden;
}
</style>
复制代码
src/
下建立一个icons
目录,目录结构以下:svg
目录主要用于存放svg
文件,来看一下index.js
的内容,功能就是把组件注册到全局,方便使用:git
import Vue from 'vue'
import SvgIcon from '@/components/SvgIcon' // svg组件
// 注册到全局
Vue.component('svg-icon', SvgIcon)
const requireAll = requireContext => requireContext.keys().map(requireContext)
const req = require.context('./svg', false, /\.svg$/)
requireAll(req)
复制代码
固然,若是你有本身的想法或需求,能够单独引入,无需非要注册到全局。github
main.js
中引入好了,接下来是最重要的一步:web
loader
:你们能够去vue-cli3官网去查看具体教程,这里我只说须要修改的loader
以及具体的代码实现。vue-router
首先须要注意的是,经过vue-cli3
构建的项目能够初始化进行不少选择,我构建的目录更多的是以*.config.js
的形式存在的。vuex
在根目录下建立一个名为vue.config.js
文件,接下来的操做都和它有关,先来看一下它完整的代码:vue-cli
const path = require('path')
function resolve (dir) {
return path.join(__dirname, './', dir)
}
module.exports = {
chainWebpack: config => {
config.plugin('define').tap(args => {
const argv = process.argv
const icourt = argv[argv.indexOf('--icourt-mode') + 1]
args[0]['process.env'].MODE = `"${icourt}"`
return args
})
// svg rule loader
const svgRule = config.module.rule('svg') // 找到svg-loader
svgRule.uses.clear() // 清除已有的loader, 若是不这样作会添加在此loader以后
svgRule.exclude.add(/node_modules/) // 正则匹配排除node_modules目录
svgRule // 添加svg新的loader处理
.test(/\.svg$/)
.use('svg-sprite-loader')
.loader('svg-sprite-loader')
.options({
symbolId: 'icon-[name]',
})
// 修改images loader 添加svg处理
const imagesRule = config.module.rule('images')
imagesRule.exclude.add(resolve('src/icons'))
config.module
.rule('images')
.test(/\.(png|jpe?g|gif|svg)(\?.*)?$/)
},
configureWebpack: {
devServer: {
open: true,
// https: true,
proxy: {
'/user': {
target: 'https://devadminschool.icourt.cc',
},
'/live': {
target: 'https://devadminschool.icourt.cc',
},
},
},
},
}
复制代码
你们忽略可有可无的代码,重点从svg rule loader
注释开始,其实注释已经比较详细了,就是获取默认的loader
并进行相关的修改,主要有svg-loader
、images-loader
,从vue-cli3
基础loader中能够找到这两个loader
的默认配置。
// 默认的svg loader...
webpackConfig.module
.rule('svg')
.test(/\.(svg)(\?.*)?$/)
.use('file-loader')
.loader('file-loader')
.options({
name: genAssetSubPath('img')
})
// 默认的images loader...
webpackConfig.module
.rule('images')
.test(/\.(png|jpe?g|gif|webp)(\?.*)?$/)
.use('url-loader')
.loader('url-loader')
.options(genUrlLoaderOptions('img'))
复制代码
对比我一开始的代码能够看出,我把默认的svg loader
配置中使用的file-loader
改成了svg-sprite-loader
,并排除了node_modules
,把默认的images-loader
配置添加了svg
,并排除了src/icons
目录。
src/icons/svg
目录下;svg
查看源码,修改fill
属性, fill="currentColor"
,或者fill=""
,若是无此属性,就不用管,这样作是可让外部控制icon的颜色,或随父元素的color;src/icons/svg/go-back.svg
文件。以上讲的比较糙,奈何文字功底是硬伤,最后附上github demo 代码示例: 此项目也能够当作项目初始架构,内置了vue-router、vuex等。
本文以vue-cli3建立的项目为例,以前的项目能够直接去手动修改对应的loader便可。
github地址 若是对您有用,请顺手给个star...
本文是在掘金上发布的第一篇帖子,新人入驻,还请各位前辈多关怀...