欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

浅析vue cli3 封装Svgicon组件正确姿势(推荐)

程序员文章站 2022-07-04 17:02:38
vue cli3 手把手教学封装svgicon组件第一步:在src文件下新建一个放置svg文件的文件夹第二步:在components文件下新建一个svg组件这是一个 文件夹 专门用来存放项目里面需要使...

vue cli3 手把手教学封装svgicon组件

第一步:在src文件下新建一个放置svg文件的文件夹

浅析vue cli3 封装Svgicon组件正确姿势(推荐)

第二步:在components文件下新建一个svg组件

这是一个 文件夹 专门用来存放项目里面需要使用的svg文件,比如 a.svg b.svg …

浅析vue cli3 封装Svgicon组件正确姿势(推荐)

svg组件源码

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

<script type="text/ecmascript-6">
/* icon组件实现自动引入 ../../icons/svg 下面所有的图标了
*之后我们就要使用到 webpack 的 require.context。
很多人对于 require.context可能比较陌生,
直白的解释就是require.context("./test", false, /.test.js$/); 
这行代码就会去 test 文件夹(不包含子目录)
下面的找所有文件名以 .test.js 结尾的文件能被 require 的文件。 
更直白的说就是 我们可以通过正则匹配引入相应的文件模块*/
const requireall = requirecontext => requirecontext.keys().map(requirecontext)
const req = require.context('../../icons/svg', false, /\.svg$/)
requireall(req)
export default {
 name: 'svgicon',
 props: {
  iconclass: {
   type: string,
   required: true
  },
  classname: {
   type: string
  }
 },
 computed: {
  iconname () {
   return `#icon-${this.iconclass}`
  },
  svgclass () {
   if (this.classname) {
    return 'svg-icon ' + this.classname
   } else {
    return 'svg-icon'
   }
  }
 }
}
</script>

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

第三步:配置vue.config.js

  • 需要的loader
  • npm i svg-sprite-loader -d
chainwebpack: config => {
  const svgrule = config.module.rule('svg')
  svgrule.uses.clear()
  svgrule
   .use('svg-sprite-loader')
   .loader('svg-sprite-loader')
   .options({
    symbolid: 'icon-[name]'
   })
}

 以上就配置完毕

注:未注册组件在人口文件全局注册即可使用(main.js)

到此这篇关于浅析vue cli3 封装svgicon组件正确姿势(推荐)的文章就介绍到这了,更多相关vue cli3 svgicon组件内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!