Vue3+vite搭建基础架构(9)--- 使用vite-plugin-svg-icons

Vue3+vite搭建基础架构(9)--- 使用vite-plugin-svg-icons

  • 说明
  • 安装vite-plugin-svg-icons
  • 使用vite-plugin-svg-icons
    • 添加svg-icon组件和全局组件js文件
  • 测试svg雪碧图

说明

这里记录下自己在Vue3+vite的项目使用vite-plugin-svg-icons来全局使用svg雪碧图,不使用ts语法,方便以后直接使用。这里承接自己的博客Vue3+vite搭建基础架构(8)— 使用pinia-plugin-persist这篇博客,在该博客项目的基础上增加使用vite-plugin-svg-icons。

安装vite-plugin-svg-icons

命令如下,-D表示该依赖添加在package.json里面的devDependencies。

devDependencies下的依赖包,只是我们在本地或开发坏境下运行代码所依赖的,若发到线上,其实就不需要devDependencies下的所有依赖包;(比如各种loader,babel全家桶及各种webpack的插件等)只用于开发环境,不用于生产环境,因此不需要打包。

npm install vite-plugin-svg-icons -D

在webstorm里面的Terminal输入npm install vite-plugin-svg-icons -D命令安装该依赖。执行完如下:
在这里插入图片描述

package.json会增加vite-plugin-svg-icons版本号
在这里插入图片描述

使用vite-plugin-svg-icons

在src目录下的assets文件夹下新建icons文件夹来存放svg图片。在main.js里面添加该句代码:

import 'virtual:svg-icons-register'

在这里插入图片描述
在vite.config.js添加如下代码:
在这里插入图片描述
代码如下:

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
//引入path用于写别名配置,自带无须安装
import path from 'path'
//使用svg-icons插件
import { createSvgIconsPlugin } from 'vite-plugin-svg-icons'

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [
    vue(),
    // 注册所有的svg文件生成svg雪碧图
    createSvgIconsPlugin({
      iconDirs: [path.resolve(process.cwd(), "src/assets/icons")], //svg图片存放的目录
      symbolId: "icon-[name]", // symbol的id
      inject: "body-last", // 插入的位置
      customDomId: "__svg__icons__dom__" // svg的id
    })
  ],
  resolve: {
    //别名配置
    alias: {
      '~': path.resolve(__dirname, './'),
      '@': path.resolve(__dirname, 'src')
    },
    //引入文件的时候,可以忽略掉以下文件后缀
    extensions: ['.js', '.mjs', '.vue', '.json', '.less', '.css']
  }
})

启动项目发现报错,如下:
在这里插入图片描述
根据报错信息,添加fast-glob依赖,命令如下:

npm install fast-glob -D

在这里插入图片描述
再次启动项目,启动成功。
在这里插入图片描述

添加svg-icon组件和全局组件js文件

在这里插入图片描述

在components文件夹下新建一个svg-icon文件夹,在svg-icon文件夹下面创建一个index.vue写svg组件内容,代码如下:

<template>
  <div
    v-if="isExternal"
    :style="styleExternalIcon"
    class="svg-external-icon svg-icon"
  />
  <svg
    v-else
    :class="svgClass"
    aria-hidden="true"
  >
    <use :xlink:href="iconName" />
  </svg>
</template>

<script setup name="SvgIcon">
  import { computed } from 'vue'

  const props = defineProps({
    // svg图片名称
    iconClass: {
      type: String,
      required: true
    },
    //class样式名称,如果svg标签需要添加class样式,那么就需要该属性来添加svg的样式
    className: {
      type: String,
      default: ''
    }
  })

  //是否外部链接
  const isExternal = computed(() => {
    return /^(https?:|mailto:|tel:)/.test(props.iconClass)
  })

  //svg图片名称计算属性
  const iconName = computed(() => {
    return `#icon-${props.iconClass}`
  })

  //svg样式名称计算属性
  const svgClass = computed(() => {
    if (props.className) {
      return 'svg-icon ' + props.className
    } else {
      return 'svg-icon'
    }
  })

  const styleExternalIcon = computed(() => {
    return {
      mask: `url(${props.iconClass}) no-repeat 50% 50%`,
      '-webkit-mask': `url(${props.iconClass}) no-repeat 50% 50%`
    }
  })
</script>

<style scoped>
.svg-icon {
  width: 1em;
  height: 1em;
  vertical-align: -0.15em;
  fill: currentColor;
  overflow: hidden;
}

.svg-external-icon {
  background-color: currentColor;
  mask-size: cover!important;
  display: inline-block;
}
</style>

在components文件夹下新建一个index.js全局组件文件,代码如下:

//引入svg组件
import SvgIcon from './svg-icon/index'

//配置多个全局组件
const componentsConfig = [
  {
    name: 'SvgIcon',
    component: SvgIcon
  }
]

function addGlobal() {
  return {
    install: function (Vue) {
      componentsConfig.forEach((config) => {
        Vue.component(config.name, config.component)
      })
    }
  }
}
const components = addGlobal()
export default components

在main.js里面将全局组件js文件引入,文件夹下没有写指定文件时,默认会去找index开头的文件,所以这里默认引入components下的index.js文件,代码如下:
在这里插入图片描述

import { createApp } from 'vue'
//引入element-plus
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
//将element-plus里面默认语言英文改为中文,需要引入它
import zhCn from 'element-plus/dist/locale/zh-cn.mjs'
//引入dayjs日期插件
import dayjs from 'dayjs'
//引入国际化配置
import lang from './locale'
//引入router路由
import router from './router'
//引入pinia状态管理
import pinia from './store'
//引入svg-icons
import 'virtual:svg-icons-register'
//引入全局公共组件
import globalComponents from './components'
import App from './App.vue'

const app = createApp(App)
//使用element-plus,并设置语言为中文
app.use(ElementPlus, {
  locale: zhCn,
})
//通过provide全局注入工具函数
app.provide('$dayjs', dayjs)
//国际化配置使用
app.use(lang)
//使用router路由
app.use(router)
//使用pinia状态管理
app.use(pinia)
//使用全局公共组件
app.use(globalComponents)
app.mount('#app')

测试svg雪碧图

如果想要修改svg图片颜色,需要修改svg图片里面的fill属性改为currentColor,如下:
在这里插入图片描述
在views下home文件下的index.vue直接添加svg标签代码,如下:
在这里插入图片描述
浏览器结果如下,显示默认svg图片大小和颜色:
在这里插入图片描述
如果想要修改svg图片样式,增加一个class样式即可。代码如下:
在这里插入图片描述
浏览器结果如下:
发现图片大小和颜色都被改变了,效果达到了。
在这里插入图片描述
全局使用svg图片说明就到这里了。如果后面还想直接使用其他全局组件,直接在components文件夹下的index.js中componentsConfig数组添加对应的组件即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/395094.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

算法沉淀——多源 BFS(leetcode真题剖析)

算法沉淀——多源 BFS&#xff08;leetcode真题剖析&#xff09; 01.矩阵02.飞地的数量03.地图中的最高点04.地图分析 多源 BFS 是指从多个源点同时进行广度优先搜索的算法。在传统的 BFS 中&#xff0c;我们通常从一个起始点开始&#xff0c;逐层遍历所有的相邻节点。而在多…

移动端App自动化之触屏操作自动化

工作中我们经常需要对应用的页面进行手势操作&#xff0c;比如滑动、长按、拖动等&#xff0c;AppiumDriver 为我们提供一个模拟手势操作的辅助类 TouchAction&#xff0c;可以通过它对手机屏幕进行手势操作。 具体用法参见链接&#xff1a;chromedriver下载地址与webview自动…

SQL语法-where关键字的条件解析

在sql语言中有很多命令需要或者可以通过where关键字来筛选符合条件的数据 例如修改数据用到的命令—— 【update 表名 set 字段名1值1, 字段名2值2,...where 条件;】 例如删除数据用到的命令—— 【delete from 表名 where 条件;】 例如查询数据用到的命令—— 【select 字段名…

【IEEE出版、EI稳定检索】2024年机器学习与神经网络国际学术会议(MLNN 2024)

2024年机器学习与神经网络国际学术会议(MLNN 2024) 2024 International Conference on Machine learning and Neural Networks 2024年4月19-21日 中国-珠海 重要信息 大会官网&#xff1a;www.icmlnn.org(点击投稿/参会/了解会议详情&#xff09; 大会时间&#xff1a;…

一文带你了解红墨水实验!

什么是红墨水实验&#xff1f; 将焊点置于红色墨水或染料中&#xff0c; 让红墨水或染料渗入焊点的裂纹之中&#xff0c;干燥后将焊点强行分离&#xff0c; 焊点一般会从薄弱的环节&#xff08;裂纹处&#xff09;开裂。 因此&#xff0c;红墨水实验可以通过检查开裂处界面的染…

Unity求物体关于平面镜像对称后坐标以及旋转

前言&#xff1a;如题&#xff0c;我在已知一个平面L和物体A&#xff0c;我希望得到镜像后的物体B的位置和旋转。 效果&#xff1a; 推导&#xff1a; 首先我们需要知道物体的对称坐标A&#xff0c;我们现在能已知A坐标以及平面L的法线&#xff0c;如果我们能得到B的坐标&…

vue3中基于路由层面和组件层面进行用户角色及权限控制的方法解析

文章目录 一、权限控制二、路由层面控制三、组件层面控制1、使用自定义指令2、使用方法控制3、封装一个权限控制组件来实现组件层面控制权限3.1、组件页面 Authority.vue3.2、使用页面 app.vue3.3、效果预览 一、权限控制 随着前端技术的不断发展&#xff0c;越来越多的前端框…

曲线生成 | 图解B样条曲线生成原理(基本概念与节点生成算法)

目录 0 专栏介绍1 什么是B样条曲线&#xff1f;2 基函数的de Boor递推式3 B样条曲线基本概念图解4 节点生成公式 0 专栏介绍 &#x1f525;附C/Python/Matlab全套代码&#x1f525;课程设计、毕业设计、创新竞赛必备&#xff01;详细介绍全局规划(图搜索、采样法、智能算法等)…

AIGC ChatGPT4完成业务需求SQL学习

源表如下&#xff1a; 例如现在需要显示每个岗位中工资排名前10位的员工信息&#xff0c;并显示排名应该要怎么做呢&#xff1f; Prompt: 有一个某公司职员表&#xff0c;表名为Bank_emp&#xff0c;empno为员工编号&#xff0c;ename为员工姓名&#xff0c;JOB为员工岗位&…

Codeforces Round 924 (Div. 2)题解(A-D)

A - Rectangle Cutting 链接&#xff1a;A - Rectangle Cutting 思路 考虑横边和纵边&#xff0c;若为偶数&#xff0c;则从中间分开&#xff0c;重新组合为一个长方形&#xff0c;检测是否与原来的长方形一致。 代码 #include <bits/stdc.h> using namespace std;i…

H62410Y 100V高压DCDC降压恒压芯片 可用于仪表仪器供电方案

H62410Y是一种内置100V耐压MOS&#xff0c;支持输入高达90V的高压降压开关控制器&#xff0c;可以向负载提供0.5A的连续电流。H62410Y支持输出恒定电压&#xff0c;可以通过调节VFB采样电阻来设置输出电压&#xff0c;同时支持最大电流限制&#xff0c;可以通过修改CS采样电阻来…

KMS密钥管理有哪些安全功能

KMS(Key Management Service)密钥管理服务是一种专门用于管理和保护加密密钥的系统。在现代的信息安全领域中&#xff0c;密钥的重要性不言而喻&#xff0c;它是确保数据加密、解密以及身份验证等安全操作的核心要素。KMS的出现&#xff0c;极大地提高了密钥管理的效率和安全性…

羊大师的羊奶有几种口味呢?

羊大师提供的羊奶有6种不同口味可供选择。 1.新鲜羊奶不仅没有膻味&#xff0c;而且富含高钙无糖&#xff0c;并且含有丰富的优质蛋白质和超过200种营养物质。这非常适合缺钙或体弱的人饮用。 2.益生菌羊奶是一种含有保加利亚乳杆菌、嗜酸乳杆菌、双歧杆菌等益生菌群的产品&…

无水印视频下载怎么做?这三个方法轻松搞定

在互联网时代&#xff0c;视频已成为我们获取信息、娱乐休闲的重要媒介。然而&#xff0c;有时我们可能会遇到网络不佳、时间限制或设备限制等情况&#xff0c;导致无法在线流畅观看视频。这时&#xff0c;视频下载工具就显得尤为重要。它们能够帮助我们轻松下载在线视频&#…

(个人学习之计算机网络知识总结)

备注:本人写这个计算机网络的知识点只是用于个人学习。 TCP/IP协议 从字面意义上讲&#xff0c;有人可能会认为 TCP/IP 是指 TCP 和 IP 两种协议。实际生活当中有时也确实就是指这两种协议。然而在很多情况下&#xff0c;它只是利用 IP 进行通信时所必须用到的协议群的统称。…

HTTP基本概念-HTTP 常见的状态码有哪些?

资料来源 : 小林coding 小林官方网站 : 小林coding (xiaolincoding.com) HTTP 常见的状态码有哪些? 1xx 类状态码属于提示信息&#xff0c;是协议处理中的一种中间状态&#xff0c;实际用到的比较少。 2xx 类状态码表示服务器成功处理了客户端的请求&#xff0c;也是我们最愿…

netfilter

netfilter 是 linux 网络系统中的一个子系统&#xff0c;从名字也能看出来 netfilter 的作用&#xff1a;网络过滤&#xff0c;linux 内核中网络报文的处理会经历多个协议层&#xff0c;多个环节。netfilter 即在报文处理路径上加上检查点&#xff0c;每个检查点都可以设置一些…

【算法】基础算法002之滑动窗口(二)

&#x1f440;樊梓慕&#xff1a;个人主页 &#x1f3a5;个人专栏&#xff1a;《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》《实训项目》《C》《Linux》《算法》 &#x1f31d;每一个不曾起舞的日子&#xff0c;都是对生命的辜负 目录 前言 5.水果成篮&#xff…

c++入门学习⑥——友元和运算符重载

目录 简介&#xff1a; 友元&#xff1a; 全局函数做友元 类做友元 成员函数做友元 运算符重载 加号运算符重载 代码示例&#xff1a; 输入输出运算符重载 ⭐cin ⭐cout 代码示例&#xff1a; 分析&#xff1a; 自增运算符重载 代码示例&#xff08;成员函数实现…

Paper - CombFold: Predicting structures of large protein assemblies 推理流程

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/136165853 CombFold 是一种新的组装技术&#xff0c;可以利用 AlphaFold-Multimer 预测的可能的亚复合物的结构&#xff0c;来构建大型蛋白质复合…