Vue3后台管理系统SVG图标

在Vue 3中,我们可以使用SVG图标的方式有多种,这里我们使用的是SVG Sprite的方式,这种方式可以帮助我们更好的管理和优化SVG图标。

首先,我们需要在项目中安装一个库,叫做svg-sprite-loader,这个库可以帮助我们把SVG图标作为一个sprite来进行管理。




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

然后,我们需要在vue.config.js中配置这个loader,以确保我们可以正确的加载SVG图标。




const { defineConfig } = require('@vue/cli-service')
const path = require('path')
 
function resolve(dir) {
  return path.join(__dirname, dir)
}
 
module.exports = defineConfig({
  chainWebpack: (config) => {
    config.module
      .rule('svg')
      .exclude.add(resolve('src/icons'))
      .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()
  }
})

然后,我们需要创建一个用于存放SVG图标的文件夹,并且在这个文件夹中,我们需要创建一个index.js文件,这个文件会帮助我们导入所有的SVG图标,并且注册为Vue组件。




// src/icons/index.js
 
import { App } from 'vue'
import { resolve } from 'path'
import { readDirSync } from './utils'
 
const req = require.context('./svg', false, /\.svg$/)
const requireAll = (requireContext) => requireContext.keys().map(requireContext)
 
requireAll(req)
 
const install = (app) => {
  req.keys().forEach((key) => {
    const componentConfig = req(key)
    app.component(componentConfig.default.id.split('&')[1], componentConfig.default)
  })
}
 
export default { install }

在上面的代码中,我们使用了require.context来帮助我们导入./svg文件夹中的所有SVG图标文件。然后,我们通过遍历这些图标,把它们注册为Vue组件。

最后,我们需要在main.js中注册这个icons插件,以便所有的SVG图标都可以作为Vue组件来使用。




import { createApp } from 'vue'
import App from './App.vue'
import icons from './icons'
 
const app = createApp(App)
app.use(icons)
app.mount('#app')

现在,我们可以在任何组件中使用SVG图标了,只需要像使用普通组件一样使用它们即可。




<template>
  <div>
    <home-icon />
  </div>
</template>
 
<script>
import { defineComponent } from 'vue'
import HomeIcon fr
VUE
最后修改于:2024年08月15日 17:38

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日