31、vue-cli3引入封装svg图标

mac2025-08-21  12

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]' }) } }

如果项目不能成功显示SVG,可以尝试重新启动项目。
最新回复(0)