概述
一 . 代码
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图标一 . 代码二. 环境所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复