我是靠谱客的博主 怡然篮球,最近开发中收集的这篇文章主要介绍vue3.0项目中添加svg图标一 . 代码二. 环境,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

一 . 代码

1. 在 ./src/components 路径下添加通用组件

<template>
  <svg :class="svgClass" aria-hidden="true">
    <use :xlink:href="iconName" />
  </svg>
</template>

<script>
export default {
  name: "SvgIcon",
  props: {
    iconClass: {
      type: String,
      required: true,
    },
    className: {
      type: String,
      default: "",
    },
  },
  computed: {
    iconName() {
      return `#icon-${this.iconClass}`;
    },
    svgClass() {
      if (this.className) {
        return "svg-icon " + this.className;
      } else {
        return "svg-icon";
      }
    },
  },
};
</script>

<style scoped>
.svg-icon {
  width: 1em;
  height: 1em;
  vertical-align: -0.15em;
  fill: currentColor;
  overflow: hidden;
}
</style>

2. 在 ./src/assets 建立对应文件夹和文件

3. 修改 ./src/assets/icons/index.js 文件

import SvgIcon from '@/components/SvgIcon' // svg组件

const req = require.context('./svg', false, /.svg$/)
const requireAll = requireContext => requireContext.keys().map(requireContext)
requireAll(req)

export default {
  install: app => {
    app.component('SvgIcon', SvgIcon)
  }
}

4. 在main.js中将文件引入

import { createApp } from 'vue'
import Cookies from 'js-cookie'

// 样式
import Element from 'element-plus'
import 'element-plus/dist/index.css'

import App from './App.vue'
import router from './router'
import store from './store'

// svg图标
import SvgIcon from './assets/icons' 

// 引入样式
import '@/assets/styles/index.scss'

// 基础
const app = createApp(App)

// 引用
app.use(store)
app.use(router)
app.use(SvgIcon)
app.use(Element, {
  size: Cookies.get('size') || 'default' // set element-ui default size
})

// 构建
app.mount('#app')

在这里插入图片描述

5. 运用方式

<svg-icon icon-class="password" />

二. 环境

1. 安装 svg-sprite-loader

npm install svg-sprite-loader --save-dev

2. 配置 vue.config.js 文件

chainWebpack: config => {
    // 添加svg文件
    config.module.rule('svg').exclude.add(resolve('src/assets/icons')).end()
    config.module
      .rule('icons')
      .test(/.svg$/)
      .include.add(resolve('src/assets/icons'))
      .end()
      .use('svg-sprite-loader')
      .loader('svg-sprite-loader')
      .options({
        symbolId: 'icon-[name]'
      })
      .end()

    // 编译某些npm包里的es6代码
    config.module
      .rule('vxe')
      .test(/.js$/)
      .include.add(resolve('node_modules/vxe-table'))
      .add(resolve('node_modules/vxe-table-plugin-antd'))
      .end()
      .use()
      .loader('babel-loader')
      .end()
  }

END

最后

以上就是怡然篮球为你收集整理的vue3.0项目中添加svg图标一 . 代码二. 环境的全部内容,希望文章能够帮你解决vue3.0项目中添加svg图标一 . 代码二. 环境所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(51)

评论列表共有 0 条评论

立即
投稿
返回
顶部