返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue3中级指南之如何在vite中使用svg图标详解
  • 837
分享到

Vue3中级指南之如何在vite中使用svg图标详解

2024-04-02 19:04:59 837人浏览 薄情痞子
摘要

目录前言vite-plugin-svg-icons安装使用如何在组件中使用创建SvgIcon组件icons目录结构全局注册组件页面使用获取所有 SymbolId总结前言 svg图片在

前言

svg图片在项目中使用的非常广泛,今天记录一下我是如何在vue3 + vite 中使用svg图标。

vite-plugin-svg-icons

  • 预加载 在项目运行时就生成所有图标,只需操作一次 dom
  • 高性能 内置缓存,仅当文件被修改时才会重新生成

安装

node version:  >=12.0.0 vite version:  >=2.0.0

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')],
        // 指定symbolId格式
        symbolId: 'icon-[dir]-[name]',

        
        // inject?: 'body-last' | 'body-first'

        
        // customDomId: '__svg__icons__dom__',
      }),
    ],
  }
}
  • 在 src/main.js 内引入注册脚本
import 'virtual:svg-icons-reGISter'

如何在组件中使用

创建SvgIcon组件

/src/components/SvgIcon/index.Vue

<template>
  <svg aria-hidden="true" class="svg-icon" :width="props.size" :height="props.size">
    <use :xlink:href="symbolId" rel="external nofollow"  :fill="props.color" />
  </svg>
</template>

<script setup>
import { computed } from 'vue'
const props = defineProps({
  prefix: {
    type: String,
    default: 'icon'
  },
  name: {
    type: String,
    required: true
  },
  color: {
    type: String,
    default: '#333'
  },
  size: {
    type: String,
    default: '1em'
  }
})
const symbolId = computed(() => `#${props.prefix}-${props.name}`)
</script>

icons目录结构

# src/icons

- icon1.svg
- icon2.svg
- icon3.svg
- dir/icon1.svg

全局注册组件

# src/main.js
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'

import ElementPlus from 'element-plus'
import 'element-plus/dist/index.CSS'

import svgIcon from "@/components/SvgIcon/index.vue";
import 'virtual:svg-icons-register'

createApp(App)
    .use(ElementPlus)
    .use(router)
    .component('svg-icon', svgIcon)
    .mount('#app')

页面使用

<template>
    <svg-icon v-if="props.icon" :name="props.icon" />
    <span v-if="props.title" slot='title'>{{ props.title }}</span>
</template>

<script setup>
const props = defineProps({
    icon: {
        type: String,
        default: ''
    },
    title: {
        type: String,
        default: ''
    }
})
</script>

获取所有 SymbolId

import ids from 'virtual:svg-icons-names'
// => ['icon-icon1','icon-icon2','icon-icon3']

总结

到此这篇关于Vue3中级指南之如何在vite中使用svg图标的文章就介绍到这了,更多相关vite使用svg图标内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Vue3中级指南之如何在vite中使用svg图标详解

本文链接: https://lsjlt.com/news/147585.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Vue3中级指南之如何在vite中使用svg图标详解
    目录前言vite-plugin-svg-icons安装使用如何在组件中使用创建SvgIcon组件icons目录结构全局注册组件页面使用获取所有 SymbolId总结前言 svg图片在...
    99+
    2024-04-02
  • vue3+vite中如何使用svg图标
    这篇“vue3+vite中如何使用svg图标”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue3+vite中如何使用svg...
    99+
    2023-06-30
  • 图文详解如何在vue3+vite项目中使用svg
    今天在vue3+vite项目练习中,在使用svg时,发现之前的写法不能用,之前的使用方法参考vue2中优雅的使用svg const req = require.context('...
    99+
    2024-04-02
  • 一文详解如何在Vue3+Vite中使用JSX
    目录JSX介绍在 Vue3 中使用 JSX安装插件(@vitejs/plugin-vue-jsx)新建 jsx 文件语法补充知识:注意事项总结JSX介绍 JSX(JavaScript...
    99+
    2023-02-16
    vue3 vite使用jsx vue3+vite 前端 vite搭建vue3
  • css中如何使用SVG图标
    这篇文章主要为大家展示了“css中如何使用SVG图标”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css中如何使用SVG图标”这篇文章吧。使用 SVG 图标没有理由不使用 SVG 图标:.log...
    99+
    2023-06-27
  • 在Vue3中如何更优雅的使用echart图表详解
    目录前言封装思路引入模块封装功能使用例子总结前言 在大屏可视化项目中,我们常常需要用到很多的图表组件,通常你会编写很多的option对图表进行渲染,以及引入它们所需的一些组件并使用e...
    99+
    2024-04-02
  • 一文详解如何在Vue3中使用jsx/tsx
    目录JSX 如何用插值条件渲染(v-if)列表循环(v-for)事件绑定事件修饰符v-model插槽最后我们都知道,通常情况下我们使用 vue 大多都是用的 SFC(Signle F...
    99+
    2023-03-23
    Vue3使用jsx/tsx Vue3 jsx/tsx Vue jsx tsx
  • 详解vue3中如何使用youtube-player
    目录正文开始使用做成组件youtubePlayer使用方式注意事项常用参数常用API正文 youtube-player 是 YouTube IFrame Player API&nbs...
    99+
    2024-04-02
  • 详解vue3中如何使用shaka-player
    目录正文开始使用做成组件shakaPlayer使用方式注意事项正文 Shaka Player 是谷歌公司对外开源的一款 JavaScript 类库,详细请看谷歌官方API文档。 开始...
    99+
    2024-04-02
  • Vue3中element-plus全局使用Icon图标的过程详解
    目录1、安装图标库2、注册3、在组件中直接使用4、在el-menu组件中动态使用总结Vue项目中使用Element-plus的Icon图标,包括按钮和动态菜单 1、安装图标库 npm...
    99+
    2024-04-02
  • 如何在vue3中优雅的使用jsx/tsx详解
    目录前言安装插件(@vitejs/plugin-vue-jsx)1、插值2、class与style 绑定3、条件渲染4、列表渲染5、事件处理6、v-model7、slot插槽8、使用...
    99+
    2024-04-02
  • 详解在OpenCV中如何使用图像像素
    目录切片操作获取感兴趣区域的坐标值使用切片操作裁剪图像1.加载并显示原始图像2.获取图像的空间维度3.裁剪图像4.使用尺寸将部分图像设置为特定颜色。总结 像素是计算机视觉中图像的重要...
    99+
    2024-04-02
  • 详解如何在Vue3+TS的项目中使用NProgress进度条
    目录写在前面 在项目中安装 简单的封装 在Vue切换路由时展示进度条写在前面 NProgress是一个轻量级的进度条组件,在Github上已经2.4万star数了,虽然这个组件已经好...
    99+
    2024-04-02
  • 如何在Python中使用git和npm?快速指南。
    在Python开发中,使用git和npm是非常常见的。git是一个版本控制系统,npm是一个包管理器,它们可以帮助我们更好地管理代码和依赖项。本文将介绍如何在Python中使用git和npm。 安装git和npm 首先,您需要安装gi...
    99+
    2023-07-24
    load npm git
  • 在vue3项目中如何使用新版高德地图
    这篇文章主要讲解了“在vue3项目中如何使用新版高德地图”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“在vue3项目中如何使用新版高德地图”吧!1. 首先你要注册好账号登录2. 获取key和...
    99+
    2023-07-05
  • 详解如何使用beegoorm在postgres中存储图片
    目录Postgres如何存储文件bytea类型Large ObjectBeego orm如何存储图片Postgres如何存储文件 postgres提供了两种不同的方式存储二进制,要么...
    99+
    2023-05-17
    beego orm postgres存储图片 beego orm 存储
  • Vue3中如何使用异步请求示例详解
    目录1、前言2、快速开始2.1、思路2.2、安装&封装axios2.3、设计接口2.4、设计视图2.5、最终效果总结1、前言 接上节,我们初步体验了layui-vue的用法。...
    99+
    2024-04-02
  • vue如何在style标签中使用变量(数据)详解
    目录在 style 中使用 data 变量那么如何在代码中使用style属性呢?总结参考资料 SFC CSS Features | Vue.js 在 style 中使用 data 变...
    99+
    2024-04-02
  • 如何解决png图片在html中IMG标签使用问题
    这篇文章给大家分享的是有关如何解决png图片在html中IMG标签使用问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 规画png图片在html中IMG标签使用PNG图片IE...
    99+
    2024-04-02
  • 如何在Java中调用DLL:详细图解
    如何在Java中调用DLL:详细图解 在Java开发中,有时候需要与动态链接库(DLL)进行交互,以实现更高级的功能。本文将详细介绍如何使用Java调用DLL,并提供相应的代码和描述。 第一步:准备D...
    99+
    2023-10-22
    java 开发语言 Java
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作