手摸手,优雅实现vue中使用 svg-icon

svg

 1. 安装依赖

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

#yarn add svg-sprite-loader

`svg-sprite-loader` 是 webpack loader,可将多个 svg 打包成 svg-sprite

安装完后还需要进行改造,原因是:`vue-cli` 默认情况下会使用 `url-loader` 对svg进行处理,会将它放在 `/img` 目录下,这时候引入`svg-sprite-loader`会引起冲突

//默认`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]')

    }

}

改造:

  • `svg-sprite-loader` 只处理指定文件下的svg
  •  `url-loader` 只处理指定文件以外的所有svg

vue-cli2

在webpack.base.conf.js的 `rules` 中加上:

{

    test: /\.svg$/,

    loader: 'svg-sprite-loader',

    include: [resolve('src/icons')],

    options: {

        symbolId: 'icon-[name]' // name代表图标的名字

    }

},

{

    test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,

    loader: 'url-loader',

    exclude: [resolve('src/icons')], // 使用exclude排除src/icons,让url-loader只处理除此文件夹之外的svg

    options: {

        limit: 10000,

        name: utils.assetsPath('img/[name].[hash:7].[ext]')

    }

}

vue-cli3 在 `vue.config.js` 中添加如下webpack的配置

const path = require("path");

function resolve(dir) {

    return path.join(__dirname, dir);

}

module.exports = {

    chainWebpack(config) {

        config.module

            .rule("svg")

            .exclude.add(resolve("src/icons")) // 使用exclude排除src/icons,让url-loader只处理除此文件夹之外的svg

            .end();

        config.module

            .rule("icons")

            .test(/\.svg$/)

            .include.add(resolve("src/icons"))

            .end()

            .use("svg-sprite-loader")

            .loader("svg-sprite-loader")

            .options({

                symbolId: "icon-[name]",

            })

            .end();

    },

};

2. 在 `@/src/components` 下新建 `SvgiCon.vue`组件

<template>

    <svg :class="svgClass" aria-hidden="true">

        <use :xlink:href="iconName"></use>

    </svg>

</template>



<script>

export default {

    name: "svg-icon",

    props: {

        iconClass: {

            type: String,

            required: true,

        },

        className: {

            type: String,

        },

    },

    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>

3. 在src目录下新建icons、svg文件夹和index.js文件,目录结构如下

svg 文件夹存放要使用的 .svg 图片,然后使用 index.js 自动引入 `@/src/icons/svg` 下的所有图标

index.js 如下:

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$/)

// 加载目录下所有 .svg文件

requireAll(req)

这样每次只要增删改对应的图标,就会自动生成 `svg symbol`

 4. 在 `main.js`中引入

import './icons'

5. 在页面中使用

<svg-icon iconClass="chart"></svg-icon>

iconClass的赋值名字要和svg文件名一致

ps:index.js中require.context的使用

一般情况下,文件引入使用import,但是像这种情况,文件夹下有多个svg文件,如果单个import,就会很繁琐,而且以后增加了svg文件,都需要修改index.js,针对这种场景,就需要用到context,此方法接受三个参数,文件路径,是否引入文件的子目录,正则匹配文件,如

const req = require.context('./svg', false, /.svg$/)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
vue2-svg-icon 是一个 Vue.js 的 SVG 图标组件,可以用于快速加载和使用 SVG 图标。以下是使用步骤: 1. 安装 vue2-svg-icon 可以使用 npm 或 yarn 进行安装: ```bash npm install vue2-svg-icon --save ``` 或者 ```bash yarn add vue2-svg-icon ``` 2. 引入组件 在你的 Vue.js 组件引入 vue2-svg-icon: ```js import SvgIcon from 'vue2-svg-icon' Vue.component('svg-icon', SvgIcon) ``` 3. 使用组件 在模板使用 `svg-icon` 标签,并指定 `icon` 属性为对应的图标名称: ```html <svg-icon icon="arrow-up"></svg-icon> ``` 其 `arrow-up` 是图标的名称,具体的图标名称需要查看你所使用的 SVG 图标库。 4. 配置 SVG 图标库 vue2-svg-icon 默认使用的是 [icomoon](https://icomoon.io/) 的 SVG 图标库,你可以在 `SvgIcon` 组件通过 `set` 方法来配置使用其他的 SVG 图标库。 例如,如果你想使用 [fontawesome](https://fontawesome.com/) 的 SVG 图标库,可以这样配置: ```js import SvgIcon from 'vue2-svg-icon' import { library } from '@fortawesome/fontawesome-svg-core' import { faCoffee } from '@fortawesome/free-solid-svg-icons' import { FontAwesomeIcon } from '@fortawesome/vue-fontawesome' library.add(faCoffee) Vue.component('font-awesome-icon', FontAwesomeIcon) SvgIcon.set({ name: 'fontawesome', classPrefix: 'fa-', classSuffix: '', defaultWidth: '1em', defaultHeight: '1em' }) ``` 这里我们使用了 `@fortawesome/fontawesome-svg-core` 和 `@fortawesome/free-solid-svg-icons` 来引入 fontawesome 的 SVG 图标库,并且配置了 `SvgIcon` 组件使用 `fontawesome` 图标库,并指定了图标的 class 前缀为 `fa-`,这样我们就可以在模板使用 `fa-coffee` 这个图标了: ```html <svg-icon icon="fa-coffee"></svg-icon> ``` 更多关于 vue2-svg-icon使用方法,可以参考它的官方文档:https://github.com/cenkai88/vue-svg-icon#readme

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值