vue + vite 图标导入总结

news2025/1/16 5:40:16

vue + vite 图标导入总结

SVG 的使用

在页面中我们会使用到各种图标,为了保证图标在放大缩小不失真,通常会采用 SVG 来作为图标。

SVG(Scalable Vector Graphics)是一种基于XML的矢量图像格式,它可以用来创建清晰的、可缩放的图形,无论放大多少倍都不会失真。在Web开发中,SVG常用于制作图标,因为它具有以下优点:

  • 清晰度:SVG图标在任何分辨率下都能保持清晰。
  • 可编辑性:SVG是文本格式,可以使用文本编辑器进行修改。
  • 尺寸小:SVG图标文件通常比位图(如PNG或JPEG)更小,尤其在需要多个尺寸时。
  • 动画支持:SVG支持动画,可以通过CSS或JavaScript实现动态效果。
  • 可编程性:可以使用CSS或JavaScript直接操作SVG元素。

以下是SVG图标在HTML中直接使用的简单代码示例:

html<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <style>
        /* 你可以通过CSS来控制SVG图标 */
        .my-icon {
            width: 24px;
            height: 24px;
            fill: currentColor; /* 这会让SVG填充颜色跟随父元素的颜色 */
        }
    </style>
</head>
<body>
    <!-- 直接内联SVG图标 -->
    <svg class="my-icon" viewBox="0 0 24 24" id="icon-example">
        <path d="M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7l3.59 3.59L17 7.41 15.59 9 12 12.59z"></path>
    </svg>

    <!-- 或者通过<use>标签引用外部SVG文件中的图标 -->
    <svg class="my-icon">
        <use xlink:href="#icon-example"></use> <!-- icons.svg是SVG文件,icon-example是图标在文件中的ID -->
    </svg>
</body>
</html>

在这个例子中,我们创建了两个SVG图标。第一个是内联SVG,直接在HTML中定义了图标路径。第二个是通过 <use> 标签引用了一个外部SVG文件中的图标。viewBox 属性定义了SVG的视口,d 属性包含了描述图形路径的数据。

注意,如果你使用 <use> 标签,你需要确保外部SVG文件已经被正确引入到你的HTML文档中,通常是通过<script><link> 标签。

阿里的 iconfont 的 symbol 引用就是通过 script 标签引入的,其原理是将所有图标的 svg 标签及内部 path 标签定义为字符串放在 iconfont.js 文件中,当 js 文件引入到页面后会将图标的字符串通过 innerHTML 转化为 DOM 标签作为 body 的第一个子元素插入到页面,代码如下:

i = function() {
    var t, e = document.createElement("div");
    e.innerHTML = n._iconfont_svg_string_4570457,
    (e = e.getElementsByTagName("svg")[0]) && (e.setAttribute("aria-hidden", "true"),
    e.style.position = "absolute",
    e.style.width = 0,
    e.style.height = 0,
    e.style.overflow = "hidden",
    e = e,
    (t = document.body).firstChild ? s(e, t.firstChild) : t.appendChild(e))
}
,
document.addEventListener ? ~["complete", "loaded", "interactive"].indexOf(document.readyState) ? setTimeout(i, 0) : (o = function() {
    document.removeEventListener("DOMContentLoaded", o, !1),
    i()
}

在这里插入图片描述

通过插件导入 icon 图标

vite-plugin-svg-icons 方式

针对每个图标都是一个 svg 文件这种情况,如果要单个引入就比较麻烦。假设图标都放在 src/assets/svg 目录下

在这里插入图片描述

我们可以使用 vite-plugin-svg-icons 插件来完成,其功能如下:

  • 预加载所有图标,项目运行时生成所有图标,只需操作DOM一次
  • 内置高速缓存功能,只有在文件被修改时才会重新生成
# 安装
yarn add vite-plugin-svg-icons -D
# or
npm i vite-plugin-svg-icons -D
# or
pnpm install vite-plugin-svg-icons -D

安装完成后需要在 vite.config.ts 进行如下配置:

import { createSvgIconsPlugin } from 'vite-plugin-svg-icons'
import path from 'path'

export default () => {
  return {
    plugins: [
      createSvgIconsPlugin({
        // 指定要导入的图标所在的文件夹。
        iconDirs: [path.resolve(process.cwd(), 'src/icons')],
        // 指定symbol id的格式
        symbolId: 'icon-[dir]-[name]',

        /**
         * 定义图标插入的位置
         * @default: body-last
         */
        inject?: 'body-last' | 'body-first'

        /**
         * 定义 svg 标签的 id 值
         * @default: __svg__icons__dom__
         */
        customDomId: '__svg__icons__dom__',
      }),
    ],
  }
}

src/main.ts 文件中引入注册脚本

import 'virtual:svg-icons-register'

以下是插入到页面的 svg 标签及图标,可以看出所有的图标都有加载

在这里插入图片描述

对于 svg 图标一般是修改其颜色和大小,通常会套一个 i 标签来定义,同时会传入一个图标名称,这三者作为组件的属性,这样就可以定义一个 ICON 组件了

<!-- src/components/icon.vue -->
<style>
.icon {
    height: 1em;
    width: 1em;
    line-height: 1em;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    position: relative;
    fill: currentColor;
    font-size: inherit;
}
</style>
<template>
    <i class="icon" :style="{ color: color, fontSize: size + 'px' }">
        <svg aria-hidden="true">
            <use :xlink:href="symbolId"></use>
        </svg>
    </i>
</template>
<script setup lang="ts">
import { computed, unref } from 'vue';

const props = defineProps({
    prefix: {
      type: String,
      default: 'icon',
    },
    // icon name
    iconName: {
        type: String,
        required: true,
    },
    // icon color
    color: {
        type: String,
        default: '#000'
    },
    // icon size
    size: {
        type: Number,
        default: 16
    }
})
const symbolId = computed(() => `#${props.prefix}-${props.iconName}`)
</script>

使用

<template>
    <icon iconName="add" />
    <icon iconName="delete" />
    <icon iconName="export" />
    <icon iconName="edit" />
</template>
<script setup lang="ts">
	import Icon from "@/components/Icon.vue";
</script>

效果如下图:

在这里插入图片描述

该插件原理大致总结为:根据 iconDirs 提供的图标所在的文件夹自动查找所有的 SVG 文件,将这些 SVG 文件全部添加到 svg 标签下,每一个图标对应一个 symbol 标签,每个标签的 id 为配置项中 symbolId 。通过 use :xlink:href="symbolId" 引用图标。

unplugin-icons 方式

GitHub - unplugin/unplugin-icons 是一个用于优化图标管理与使用的开发插件,它允许开发者以一种高效且自动化的形式在项目中使用图标,无需手动创建或导入每一个图标组件。使用此插件不需要将图标先下载到本地,可以从一些开源的图标库中自动导入图标。其使用方式如下:

安装

npm i -D unplugin-icons

安装图标库:使用 Iconify 作为图标库

# 安装完整版本
npm i -D @iconify/json
# 按图标集安装,例如,要安装 Material Design Icons
npm i -D @iconify-json/mdi

vite.config.ts 进行如下配置:

// vite.config.ts
import Icons from 'unplugin-icons/vite'

export default defineConfig({
  plugins: [
    Icons({ /* options */ }),
  ],
})

使用

<script setup>
import IconAccessPointCheck from '~icons/mdi/access-point-check';
import IconAccountBox from '~icons/mdi/account-box'
</script>

<template>
  <icon-access-point-check/>
  <icon-account-box style="font-size: 2em; color: red"/>
</template>

效果如下图:

在这里插入图片描述

为了提高工作效率,通过在配置项中启用“ autoInstall ”选项,可以让 unplugin-icons 来负责安装工作,此时就不需要安装图标库了

// vite.config.ts
import Icons from 'unplugin-icons/vite'

export default defineConfig({
  plugins: [
    Icons({ 
      // experimental
      autoInstall: true,
    }),
  ],
})

在这里插入图片描述

unplugin-icons 的图标解析与转换过程总结如下:

  1. 图标名称识别
  • 在Vue模板或JSX中,开发者使用图标名称(如 <i-mdi-home></i-mdi-home>),unplugin-icons 会通过代码分析识别这些图标名称。
  1. 图标解析
  • 图标名称映射:根据配置的图标集,unplugin-icons 查找图标名称与实际图标资源之间的映射关系。这通常涉及到读取图标集的元数据,如JSON文件,里面记录了每个图标的名称和对应的SVG路径。

  • 图标资源提取:一旦找到图标名称对应的资源位置,插件会读取SVG文件或从图标库API获取SVG数据。

  1. 图标转换
  • SVG到Vue组件:获取到SVG数据后,unplugin-icons 将SVG内容转换为Vue组件代码。这个过程可能包括:
    • 图标优化:对SVG进行优化,比如去除不必要的属性、标准化样式等,确保图标在不同浏览器和平台上的表现一致。
    • 组件模板构造:构造Vue组件模板,将SVG内容包裹在Vue的<template>标签中,并添加必要的属性和事件绑定。
    • 动态导入处理:如果配置了按需加载,插件会生成动态导入代码,确保图标只在真正使用时加载。
  • 组件注册:生成的Vue组件需要在项目中注册,以便在模板中直接使用。unplugin-icons 通常会自动处理组件的注册,可能通过全局注册或按需注册的方式。
  1. 自动导入
  • 依赖注入:通过与unplugin-auto-import的集成,unplugin-icons 在编译时自动插入必要的导入语句,使得开发者无需手动导入图标组件。
  1. 最终输出
  • 编译产物:经过上述步骤,原本的图标名称在编译后的代码中被替换为实际的Vue组件调用,同时图标组件按需加载和自动导入的逻辑也被正确插入。最终,构建工具输出的代码中包含了最小化且优化过的图标组件,既减少了包体积,又简化了开发流程。

项目中注册,以便在模板中直接使用。unplugin-icons 通常会自动处理组件的注册,可能通过全局注册或按需注册的方式。

  1. 自动导入
  • 依赖注入:通过与unplugin-auto-import的集成,unplugin-icons 在编译时自动插入必要的导入语句,使得开发者无需手动导入图标组件。
  1. 最终输出
  • 编译产物:经过上述步骤,原本的图标名称在编译后的代码中被替换为实际的Vue组件调用,同时图标组件按需加载和自动导入的逻辑也被正确插入。最终,构建工具输出的代码中包含了最小化且优化过的图标组件,既减少了包体积,又简化了开发流程。

整个过程确保了图标资源的高效利用,同时保持了代码的清晰和易维护性。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

计算机组成原理之计算机的性能指标

目录 计算机的性能指标 复习提示 1.计算机的主要性能指标 1.1机器字长 1.1.1与机器字长位数相同的部件 1.2数据通路带宽 1.3主存容量 1.4运算速度 1.4.1提高系统性能的综合措施 1.4.2时钟脉冲信号和时钟周期的相关概念 1.4.3主频和时钟周期的转换计算 1.4.4IPS的相关…

图神经网络实战(13)——经典链接预测算法

图神经网络实战&#xff08;13&#xff09;——经典链接预测算法 0. 前言1. 链接预测2. 启发式技术2.1 局部启发式技术2.2 全局启发式技术 3. 矩阵分解小结系列链接 0. 前言 链接预测 (Link prediction) 可以帮助我们理解和挖掘图中的关系&#xff0c;并在社交网络、推荐系统等…

javaweb请求响应+@ResponseBody注解

这里用了一款接口测试软件postman 简单参数 SpringBoot方式 简单参数:参数名与形参变量名相同&#xff0c;定义形参即可接收参数。 请求参数名与方法形参变量名相同 会自动进行类型转换 package com.example.springbootwebreqresp.Controller;import org.springframework.w…

Go微服务: 理解分布式锁

概述 我们先看一个场景&#xff0c;到了双11&#xff0c;我们的商户又开始卖商品啦但是&#xff0c;我们的库存是有限的&#xff0c;如果超卖了&#xff0c;可能平台就会涉及相关法律责任了所以&#xff0c;我们的库存扣除问题&#xff0c;一定是一个非常经典的问题 先看上图&…

《Vue》系列文章目录

Vue (发音为 /vjuː/&#xff0c;类似 view) 是一款用于构建用户界面的 JavaScript 框架。它基于标准 HTML、CSS 和 JavaScript 构建&#xff0c;并提供了一套声明式的、组件化的编程模型&#xff0c;帮助你高效地开发用户界面。无论是简单还是复杂的界面&#xff0c;Vue 都可以…

实现3-8译码器①

描述 下表是74HC138译码器的功能表. E3 E2_n E1_n A2 A1 A0 Y0_n Y1_n Y2_n Y3_n Y4_n Y5_n Y6_n Y7_n x 1 x x x x 1 1 1 1 1 1 1 1 x x 1 x x x 1 1 1 1 1 1 1 1 0 x x x x x 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 …

C语言之argc、argv与main函数的传参

一 &#xff1a;谁给main函数传参 &#xff08;1&#xff09;调用main函数所在的程序的它的父进程给main函数传参&#xff0c;并且接收main函数的返回值 二 &#xff1a;为什么需要给main函数传参 &#xff08;1&#xff09;首先mian函数不传承是可以的&#xff0c;也就是说它的…

01-Linux网络设置

1、查看及测试网络 查看及测试网络配置是管理Linux网络服务的第一步&#xff0c;其中的大多数命令以普通用户的权限就可以完成操作&#xff0c;但普通用户在执行/sbin目录中的命令时需要指定命令文件的决对路径。 1.1 查看网络接口地址 主机的网卡通常称为网络接口&#xff…

轻松驾驭视频节奏:灵活调整视频播放速度,让视频内容更出彩!

视频已经成为了我们生活中不可或缺的一部分。无论是观看电影、电视剧&#xff0c;还是浏览短视频、直播内容&#xff0c;我们都希望能够根据自己的喜好和需求来调整视频的播放速度&#xff0c;甚至精确控制每一秒的播放内容。那么&#xff0c;如何轻松实现这一愿望呢&#xff1…

torchmetrics,一个无敌的 Python 库!

更多Python学习内容&#xff1a;ipengtao.com 大家好&#xff0c;今天为大家分享一个无敌的 Python 库 - torchmetrics。 Github地址&#xff1a;https://github.com/Lightning-AI/torchmetrics 在深度学习和机器学习项目中&#xff0c;模型评估是一个至关重要的环节。为了准确…

Springboot结合redis实现关注推送

关注推送 Feed流的模式 Timeline:不做内容筛选&#xff0c;简单的按照内容发布时间排序。常用于好友与关注。例如朋友圈的时间发布排序。 优点:信息全面&#xff0c;不会有缺失。并且实现也相对简单 缺点:信息噪音较多&#xff0c;用户不一定感兴趣&#xff0c;内容获取效率…

打造精细化运维新玩法(三)

实践SLO&#xff0c;概括下就是在相对标准、统一的框架下指导和推动服务质量的数字化建设&#xff0c;形成对组织有价值的数据资产和流程规范。借用在人工智能和机器学习领域的观点&#xff0c;算法的上限受限于数据质量的好坏&#xff0c;所以从源头上建设高质量的数据非常重要…

【电赛】STM32-PID直流减速电机小车【寻迹+避障+跟随】【更新ing】

一.需求分析 1.主控&#xff1a;STM32C8T6&#xff08;没什么好说的哈哈&#xff09; 2.电机&#xff1a;JAG25-370电机 【问】为什么要用直流减速电机&#xff1f;&#xff1f; PID控制器需要依靠精确的反馈信号来调整其输出&#xff0c;确保电机按照预定的速度和位置运行…

独立游戏之路:Tap篇 -- Unity 集成 TapTap 广告详细步骤

Unity 集成 TapADN 广告详细步骤 前言一、TapTap 广告介绍二、集成 TapTap 广告的步骤2.1 进入广告后台2.2 创建广告计划2.3 选择广告类型三、代码集成3.1 下载SDK3.2 工程配置3.3 源码分享四、常见问题4.1 有展现量没有预估收益 /eCPM 波动大?4.2 新建正式媒体找不到预约游戏…

介绍Linux

目录 1.什么是操作系统 2.现实生活中的操作系统 3.操作系统的发展史 4.操作系统的发展 Linux的不同版本以及应用领域 1.Linux内核及发行版介绍 <1>Linux内核版本 <2>Linux发行版本 2.应用领域 个⼈桌⾯领域的应⽤ 服务器领域 嵌⼊式领域 3.文件和目录 …

HDFS 读写数据流程

优质博文&#xff1a;IT-BLOG-CN 一、HDFS 写数据流程 HDFS 文件写入流程图如下&#xff1a;三个模块&#xff08;客户端、NameNode、DataNode&#xff09; 【1】校验&#xff1a; 客户端通过 DistributedFileSystem 模块向 NameNode 请求上传文件&#xff0c;NameNode 会检…

Vue 面试通杀秘籍

理论篇&#xff1a; 1. 说说对 Vue 渐进式框架的理解&#xff08;腾讯医典&#xff09; a) 渐进式的含义&#xff1a; 主张最少, 没有多做职责之外的事 b) Vue 有些方面是不如 React&#xff0c;不如 Angular.但它是渐进的&#xff0c;没有强主张&#xff0c; 你可以在原有…

Java面向对象-Object类的toString方法、equals方法

Java面向对象-Object类的toString方法、equals方法 一、toString二、equals三、总结 一、toString Object的toString方法。 方法的原理&#xff1a; 现在使用toString方法的时候&#xff0c;打印出来的内容不友好。 现在想要知道对象的信息。 出现的问题&#xff1a;子类Stu…

SAP Build 2 PDF数据提取与决策树(未完成)

0. 安装desktop agent 在后续过程中发现要预先安装desktop agent&#xff0c;否则没法运行自动化流程… 0.1 agent下载 参考官方文档说明 https://help.sap.com/docs/build-process-automation/sap-build-process-automation/create-user-in-rbsc-download-repository?loca…

AI办公自动化:用Kimi批量在Excel文件名中加入日期

工作任务&#xff1a;在一个文件夹中所有的Excel文件后面加上一个日期 在Kimi中输入提示词&#xff1a; 你是一个Python编程专家&#xff0c;写一个Python脚本&#xff0c;具体步骤如下&#xff1a; 打开文件夹&#xff1a;F:\AI自媒体内容\AI行业数据分析\投融资 读取里面所…