VUE3 加载自定义SVG文件的详细步骤

 更新时间:2024年01月28日 12:25:04   作者:fendouweiqian  
要在 Vue 项目中使用 svg-sprite-loader 来管理 SVG 图标,需要执行相应的步骤,接下来通过本文给大家介绍VUE3 加载自定义SVG文件的详细步骤,感兴趣的朋友一起看看吧

网上代码通篇一律,需要修改多处地方,特别是component下还要创建一个index.vue的组件,奇奇怪怪。

要在 Vue 项目中使用 svg-sprite-loader 来管理 SVG 图标,你需要执行以下几个步骤:

npm install svg-sprite-loader -D 

步骤 1: 配置 vue.config.js

确保你的 Vue 项目的根目录中有一个 vue.config.js 文件,用于自定义 Vue CLI 的内部 webpack 配置。如果文件不存在,你可以创建一个。在这个文件中,添加以下配置:

const path = require('path');
module.exports = {
  chainWebpack: config => {
    // SVG 规则排除 icons 目录
    config.module.rule('svg')
      .exclude.add(path.resolve('src/assets/icons'))
    // 添加 icons 目录的 SVG loader
    config.module.rule('icons')
      .test(/\.svg$/)
      .include.add(path.resolve('src/assets/icons')).end()
      .use('svg-sprite-loader')
        .loader('svg-sprite-loader')
        .options({ symbolId: 'icon-[name]' })
  }
};

这个配置告诉 webpack 对于 src/assets/icons 目录中的 .svg 文件,使用 svg-sprite-loader 来处理它们。其他目录中的 .svg 文件将使用项目中默认的 SVG loader。

步骤 2: 添加 SVG 图标

将你的 SVG 图标放置在 src/assets/icons 目录中。例如,你可以有一个名为 example.svg 的图标。

一个简单的 SVG 图标可能看起来像这样:

<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24">
    <path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z"/>
</svg>

步骤 3: 全局引入 SVG 图标

在项目的入口文件(通常是main.jsmain.ts)中添加全局 SVG 导入。例如:

import { createApp } from 'vue';
import App from './App.vue';
// 导入 SVG 图标
const req = require.context('./assets/icons', false, /\.svg$/);
const requireAll = context => context.keys().map(context);
requireAll(req);
createApp(App).mount('#app');

步骤 4: 使用 SVG 图标

在你的组件中,你应该能够通过 symbolId 引用 SVG 图标,就像这样:

<template>
  <svg class="icon" aria-hidden="true">
    <use xlink:href="#icon-example" rel="external nofollow" ></use>
  </svg>
</template>

其中 icon-example 是你的 SVG 文件名。

步骤 5: 重新编译

现在,你可以在任何组件中使用这些 SVG 图标。图标的 ID 将基于文件名,例如 icon-example 对应于 example.svg 文件。

请注意,这些步骤假设你的 Vue 项目是基于 Vue CLI 创建的。如果你的项目结构有所不同,可能需要相应地调整配置和路径。

到此这篇关于VUE3 加载自定义SVG文件的详细步骤的文章就介绍到这了,更多相关VUE3 加载自定义SVG文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 关于vue-router的使用及实现原理

    关于vue-router的使用及实现原理

    这篇文章主要介绍了关于vue-router的使用及实现原理,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • vue实现的微信机器人聊天功能案例【附源码下载】

    vue实现的微信机器人聊天功能案例【附源码下载】

    这篇文章主要介绍了vue实现的微信机器人聊天功能,结合实例形式分析了基于vue.js的微信机器人聊天相关界面布局、ajax交互等操作技巧,并附带源码供读者下载参考,需要的朋友可以参考下
    2019-02-02
  • 详解vue-cli项目中的proxyTable跨域问题小结

    详解vue-cli项目中的proxyTable跨域问题小结

    这篇文章主要介绍了详解vue-cli项目中的proxyTable跨域问题小结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-02-02
  • 解决vue创建项目使用vue-router和vuex报错Object(...)is not a function

    解决vue创建项目使用vue-router和vuex报错Object(...)is not a&nb

    这篇文章主要介绍了解决vue创建项目使用vue-router和vuex报错Object(...)is not a function问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-02-02
  • vue-cli3+typescript初体验小结

    vue-cli3+typescript初体验小结

    这篇文章主要介绍了vue-cli3+typescript初体验小结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-02-02
  • elementUI组件el-dropdown(踩坑)

    elementUI组件el-dropdown(踩坑)

    本文主要介绍了elementUI组件el-dropdown的一些坑,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • Vue2.0 v-for filter列表过滤功能的实现

    Vue2.0 v-for filter列表过滤功能的实现

    今天小编就为大家分享一篇Vue2.0 v-for filter列表过滤功能的实现,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • Vue加载json文件的方法简单示例

    Vue加载json文件的方法简单示例

    这篇文章主要介绍了Vue加载json文件的方法,结合实例形式分析了vue.js针对json文件的加载及数据读取等相关操作技巧,需要的朋友可以参考下
    2019-01-01
  • VUE.CLI4.0配置多页面入口的实现

    VUE.CLI4.0配置多页面入口的实现

    这篇文章主要介绍了VUE.CLI4.0配置多页面入口的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • vue-cli结合Element-ui基于cropper.js封装vue实现图片裁剪组件功能

    vue-cli结合Element-ui基于cropper.js封装vue实现图片裁剪组件功能

    这篇文章主要介绍了vue-cli结合Element-ui基于cropper.js封装vue实现图片裁剪组件功能,本文图文并茂给大家介绍的非常详细,需要的朋友可以参考下
    2018-03-03

最新评论