svg图标放大不失真,png会出现失真现象。

一、方法一

1、在对应vue项目里添加插件

vue add svg-sprite

输入 Y

2、再执行

npm install svgo svgo-loader --save-dev

然后你就会看到 自动新增 的根目录文件vue.config.js和src/components/SvgIcon.vue,如图:

3、在main.js里注册SvgIcon组件

//引入svg组件
import SvgIcon from '@/components/SvgIcon.vue' //全局注册icon-svg
Vue.component('SvgIcon', SvgIcon)

4、再在assets下创建icons文件夹,将所有的svg图标放进去,name就是svg的名字,例如

<svg-icon name="test"></svg-icon>

如果项目不能成功显示SVG,可以尝试重新启动项目。

二、方法二

方法二需要自己配置,有些麻烦

1、在 src/components/ 下创建 SvgIcon 组件

<template>
<svg :class="svgClass" aria-hidden="true" v-on="$listeners">
<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>

2、在 src/ 下创建一个 icons 目录,目录结构如下:

svg 目录主要用于存放 svg 文件,来看一下 index.js 的内容,功能就是把组件注册到全局,方便使用:

import Vue from 'vue'
import SvgIcon from '@/components/SvgIcon'// svg组件 // register globally 注册到全局
Vue.component('svg-icon', SvgIcon) const req = require.context('./svg', false, /\.svg$/)
const requireAll = requireContext => requireContext.keys().map(requireContext)
requireAll(req)

当然,如果你有自己的想法或需求,可以单独引入,无需非要注册到全局。

3、 在 main.js 中引入

import './icons' // icon

4 、修改默认的 loader

npm install svg-sprite-loader --save-dev

大家可以去vue-cli3官网去查看具体教程,这里我只说需要修改的 loader 以及具体的代码实现。

首先需要注意的是,通过 vue-cli3 构建的项目可以初始化进行很多选择,我构建的目录更多的是以 *.config.js 的形式存在的。

在根目录下创建一个名为 vue.config.js 文件,接下来的操作都和它有关,先来看一下它完整的代码:

module.exports = {
chainWebpack: config => {
// 一个规则里的 基础Loader
// svg是个基础loader
const svgRule = config.module.rule('svg') // 清除已有的所有 loader。
// 如果你不这样做,接下来的 loader 会附加在该规则现有的 loader 之后。
svgRule.uses.clear() // 添加要替换的 loader
svgRule
.use('svg-sprite-loader')
.loader('svg-sprite-loader')
.options({
symbolId: 'icon-[name]'
})
}
}

使用

abc是文件名,在icons/svg中存放svg文件

<svg-icon icon-class="abc" />
如果项目不能成功显示SVG,可以尝试重新启动项目。

最新文章

  1. Backbone.js
  2. Wpf 中使用gif格式的动态图
  3. CentOS7|RHEL忘记root密码
  4. 【python】list。列表
  5. live555源码研究(五)------DynamicRTSPServer类
  6. For Me ...
  7. WIN7下使用.net(C#)监视剪贴板 (转)
  8. HDU1506(单调栈或者DP) 分类: 数据结构 2015-07-07 23:23 2人阅读 评论(0) 收藏
  9. Java-抽象类定义构造方法
  10. 彻底清除Linux centos minerd木马
  11. Lustre文件系统测试——obdfilter-survey测试
  12. Linux已经全然统治了这个世界:反对开源社区愚不可及
  13. appium GUI介绍
  14. vue2.0父子组件之间通信
  15. 响应式编程知多少 | Rx.NET 了解下
  16. 推荐几个Spring Cloud学习资料
  17. 把vim插入状态的光标改为竖线
  18. [ 随手记 1 ] C/C++宏,普通函数,内联函数
  19. 针对list集合进行分页展示
  20. javascript:width,innerwidth和outerwidth的区别

热门文章

  1. docker容器内 java应用程序启动慢
  2. Nginx实现高可用(了解)
  3. oracle用imp导入dmp文件
  4. App 冷启动与热启动及启动白屏优化
  5. SpannableString设置文本背景色
  6. charles 发布Glist
  7. Linux下Eclipse以及Java环境安装教程[小白化](2019-9)
  8. Java中常用IO流之文件流的基本使用姿势
  9. 使用PrepareStatement
  10. 【Python爬虫】第四课(查询照片拍摄地址)