vue3+vite+ts 通过svg-sprite-loader 插件使用自定义图标的详细步骤
第一步
首先下载svg插件和fs模块; 后续需要用到
npm install svg-sprite-loader -D npm install fs
第二步新建文件夹和文件
将下载好的svg文件放入新建好的svg文件夹中
index.vue 代码 这里是创建一个<svg-icon />
组件
<template> <svg :class="svgClass" v-bind="$attrs" :style="{ color: color }"> <use :xlink:href="iconName"></use> </svg> </template> <script setup lang="ts"> import { computed, defineProps } from "vue"; const props = defineProps({ name: { type: String, required: true, }, color: { type: String, default: "", }, }); const iconName = computed(() => `#icon-${props.name}`); const svgClass = computed(() => { if (props.name) return `svg-icon icon-${props.name}`; return "svg-icon"; }); </script> <style scoped> .svg-icon { width: 1em; height: 1em; fill: currentColor; vertical-align: middle; } </style>
index.ts 代码
import { readFileSync, readdirSync } from "fs"; let idPerfix = ""; const svgTitle = /<svg([^>+].*?)>/; const clearHeightWidth = /(width|height)="([^>+].*?)"/g; const hasViewBox = /(viewBox="[^>+].*?")/g; const clearReturn = /(\r)|(\n)/g; // 查找svg文件 function svgFind(e) { const arr = []; const dirents = readdirSync(e, { withFileTypes: true }); for (const dirent of dirents) { if (dirent.isDirectory()) arr.push(...svgFind(e + dirent.name + "/")); else { const svg = readFileSync(e + dirent.name) .toString() .replace(clearReturn, "") .replace(svgTitle, ($1, $2) => { let width = 0, height = 0, content = $2.replace(clearHeightWidth, (s1, s2, s3) => { if (s2 === "width") width = s3; else if (s2 === "height") height = s3; return ""; }); if (!hasViewBox.test($2)) content += `viewBox="0 0 ${width} ${height}"`; return `<symbol id="${idPerfix}-${dirent.name.replace( ".svg", "" )}" ${content}>`; }) .replace("</svg>", "</symbol>"); arr.push(svg); } } return arr; } // 生成svg export const createSvg = (path: any, perfix = "icon") => { if (path === "") return; idPerfix = perfix; const res = svgFind(path); return { name: "svg-transform", transformIndexHtml(dom: String) { return dom.replace( "<body>", `<body><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" style="position: absolute; width: 0; height: 0">${res.join( "" )}</svg>` ); }, }; };
第三步 打开main.ts 将创建好的<svg-icon />组件注入到全局组件
import { createApp } from "vue"; import svgIcon from "@/icons/index.vue"; const app = createApp(App); app.component("svg-icon", svgIcon); app.mount("#app");
第四步 在根目录打开vite.config.ts
import { defineConfig } from "vite"; import vue from "@vitejs/plugin-vue"; import path from "path"; // 引入icons文件夹中的index.ts文件 import { createSvg } from "./src/icons/index"; // https://vitejs.dev/config/ export default defineConfig({ plugins: [vue(), createSvg("./src/icons/svg/")], resolve: { alias: { "@": path.resolve("./src"), // 相对路径别名配置,使用 @ 代替 src }, } });
**
注意
如果引入的文件爆红,“该目录不在项目的文件列表中,项目必须列出所有文件,或使用 “include” 模式。”
解决方案:打开根目录下的tsconfig.node.json文件的inclue中添加"src/icons/"
完整代码: “include”: [“vite.config.ts”, "src/icons/",]
**
最后使用
<svg-icon name="hamburger" width="20" height="20" />
引入成功
到此这篇关于vue3+vite+ts 通过svg-sprite-loader 插件使用自定义图标的文章就介绍到这了,更多相关vue3+vite+ts 自定义图标内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
el-input输入校验不能为空格以及不能输入全部为空的内容
这篇文章主要给大家介绍了关于el-input输入校验不能为空格以及不能输入全部为空的内容的相关资料,el-input验证规则主要是为了确保输入的内容符合特定的要求,需要的朋友可以参考下2023-10-10vue scroll滚动判断的实现(是否滚动到底部、滚动方向、滚动节流、获取滚动区域dom元素)
这篇文章主要介绍了vue scroll滚动判断的实现(是否滚动到底部、滚动方向、滚动节流、获取滚动区域dom元素),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-06-06详解Vue中$props、$attrs和$listeners的使用方法
本文主要介绍了Vue中$props、$attrs和$listeners的使用详解,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2021-12-12
最新评论