您现在的位置是:网站首页> 编程资料编程资料
vue3+vite2中使用svg的方法详解(亲测可用)_vue.js_
2023-05-24
356人已围观
简介 vue3+vite2中使用svg的方法详解(亲测可用)_vue.js_
技术栈:vue3+vite2
前言:
写过一版基于vue-cli中使用svg的方法,但是因为webpack提供了require.context()在vite中无法使用,所以基于vite构建的项目则采取另一种方法
一、安装vite-plugin-svg-icons
此处还需要安装下fast-glob相关依赖,不然vite运行npm run dev时会报Cannot find module 'fast-glob’的错误
npm i fast-glob@3.x -D npm i vite-plugin-svg-icons@2.x -D
二、在src/components/svgIcon下新建组件index.vue
三、tsconfig.json中添加设置
types用来指定需要包含的模块,只有在这里列出的模块的声明文件才会被加载进来。非必要添加,我在两个demo测试的时候,一个需要一个不需要,若有问题可以尝试添加
{ "compilerOptions": { "types": ["vite-plugin-svg-icons/client"] } } 四、vite.config.ts 中的配置插件
import { resolve } from 'path' import { createSvgIconsPlugin } from 'vite-plugin-svg-icons' export default defineConfig({ plugins: [ createSvgIconsPlugin({ // 指定需要缓存的图标文件夹 iconDirs: [resolve(process.cwd(), 'src/assets/imgs/svg')], // 指定symbolId格式 symbolId: 'icon-[dir]-[name]', }) ] }) 五、在main.ts全局注册组件
import { createApp } from 'vue' import App from './App.vue' import router from '@/router' import { store, key } from '@/store' const app = createApp(App) import 'virtual:svg-icons-register' // 引入注册脚本 import SvgIcon from '@/components/svgIcon/index.vue' // 引入组件 app.component('svg-icon', SvgIcon) app.use(router).use(store, key).mount('#app') 六、在页面中使用
七、文件目录结构及其效果展示

八、参考链接地址
1、依赖官方参考文档:https://github.com/vbenjs/vite-plugin-svg-icons/blob/main/README.zh_CN.md
2、其中有一些内容点我根据该文章进行参考:https://www.cnblogs.com/haoxianrui/archive/2022/04/02/16090029.html
3、在vue-cli中使用svg的可以参考我另一篇文章:https://www.jb51.net/article/258653.htm
总结
到此这篇关于vue3+vite2中使用svg的文章就介绍到这了,更多相关vue3+vite2使用svg内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- vue在同一个页面重复引用相同组件如何区分二者_vue.js_
- JavaScript markdown 编辑器实现双屏同步滚动_javascript技巧_
- vue设计与实现合理的触发响应_vue.js_
- 普通js文件里面如何访问vue实例this指针_javascript技巧_
- vue中使用elementui实现树组件tree右键增删改功能_vue.js_
- VueJS设计与实现之浅响应与深响应详解_vue.js_
- 快速修改antd vue单个组件的默认样式_vue.js_
- javascript算法之数组反转_javascript技巧_
- vue3.2 Composition API项目依赖升级_vue.js_
- 关于VueRouter导入的全过程_vue.js_
