vue3.0 vite引入SVG iconfont

简介: vue3.0 vite引入SVG iconfont

1.安装

cnpm i vite-plugin-svg-icons -D

2.配置 vite.config.ts

import viteSvgIcons from 'vite-plugin-svg-icons';
import path from 'path';

export default () => {
  return {
    plugins: [
      viteSvgIcons({
        // 指定需要缓存的图标文件夹
        iconDirs: [path.resolve(process.cwd(), 'src/icons')],
        // 指定symbolId格式
        symbolId: 'icon-[dir]-[name]',
      }),
    ],
  };
};

3.在 src/main.ts 内引入注册脚本

import 'virtual:svg-icons-register';

4.创建组件

//src/components/SvgIcon/index.vue

<template>
  <svg aria-hidden="true" class="svg-icon-spin">
    <use :xlink:href="symbolId" :fill="color" />
  </svg>
</template>

<script lang="ts">
  import { defineComponent, computed } from 'vue'

  export default defineComponent({
    name: 'SvgIcon',
    props: {
      prefix: {
        type: String,
        default: 'icon'
      },
      name: {
        type: String,
        required: true
      },
      color: {
        type: String,
        default: '#333'
      }
    },
    setup(props) {
      const symbolId = computed(() => `#${props.prefix}-${props.name}`)
      return { symbolId }
    }
  })
</script>
<style lang="less" scoped>
  .svg-icon-spin {
    width: 1em;
    height: 1em;
    fill: currentColor;
    vertical-align: middle;
  }
</style>

5.icons 目录结构


src/icons

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

6.使用

<template>
  <div>
    <SvgIcon name="icon1"></SvgIcon>
    <SvgIcon name="icon2"></SvgIcon>
    <SvgIcon name="icon3"></SvgIcon>
    <SvgIcon name="dir-icon1"></SvgIcon>
  </div>
</template>

<script>
  import { defineComponent, computed } from 'vue';
  import SvgIcon from './components/SvgIcon.vue';
  export default defineComponent({
    name: 'App',
    components: { SvgIcon },
  });
</script>
相关文章
|
7月前
|
JavaScript
Vue 项目使用 iconfont
Vue 项目使用 iconfont
207 0
vue3+vite项目中使用svg图标
vue3+vite项目中使用svg图标
858 0
|
2月前
|
JavaScript
vue3- antd design vue 引入iconfont
vue3- antd design vue 引入iconfont
|
3月前
|
JavaScript 前端开发
react Or vue中引入animate.css
本文介绍了如何在React或Vue项目中引入animate.css库来使用动画效果,包括通过npm安装或在线链接引入,并展示了如何在React组件和Vue路由过渡中使用动画类。
74 0
|
5月前
|
XML JavaScript 前端开发
vue实战——图标,请使用SVG!(含插件vue-svg-icon的使用)
vue实战——图标,请使用SVG!(含插件vue-svg-icon的使用)
142 1
|
7月前
|
资源调度 前端开发 JavaScript
Tailwind CSS如何在vue项目中使用
Tailwind CSS如何在vue项目中使用
226 8
|
7月前
|
JavaScript 前端开发
如何在vue项目中优雅地使用SVG
如何在vue项目中优雅地使用SVG
234 1
|
JSON JavaScript 前端开发
VUE3(七)vue项目抽离.vue文件中的js、css代码
平常再做开发的时候,一般情况下不会将html,js,css代码写到一个文件中。 基本上都会写在各自对应的文件中,然后再引入即可。
861 0
VUE3(七)vue项目抽离.vue文件中的js、css代码
|
监控 前端开发 JavaScript
React CSS-In-JS 方案 : Linaria Vs Styled-Components
在开发一个 React 应用时,其中一个比较大的挑战就是为应用选择一个合适的样式处理方案。因为我们需要考虑到样式的可维护性,开发体验,以及样式对应用性能的影响等
225 0
React CSS-In-JS 方案 :  Linaria Vs Styled-Components
|
JavaScript PHP
vue项目中使用vue-ueditor-wrap
vue项目中使用vue-ueditor-wrap
319 0

热门文章

最新文章