zoukankan      html  css  js  c++  java
  • VUE3.0 解析svg文件

    网上关于解析svg的有很多,就不白话了。

    1:在src文件夹下建立如下文件

     svg文件夹专门存放下载下来的svg文件。

    index.js用来解析svg文件。

    SvgIcon.vue是svg的公共组件,提取出来便于逻辑书写。

    2:svgicon.vue的代码。主要是公共组件的逻辑(固定即可,要做调整也可修改):

    <template>
      <svg :class="svgClass" aria-hidden="true" v-on="$listeners">
        <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 {
       1em;
      height: 1em;
      vertical-align: -0.15em;
      fill: currentColor;
      overflow: hidden;
    }
    </style>

    3:index.js的代码,主要是创建公共组件并解析svg,供main.js全局引用导出

    import Vue from 'vue'
    import SvgIcon from '../icons/SvgIcon.vue'
    //定义全局组件
    Vue.component("svg-icon", SvgIcon);
    const req = require.context("./svg", false, /.svg$/) //第一个:目录  第二个:是否遍历子级目录  3:定义遍历规则
    const requireAll = requireContext => {
        return requireContext.keys().map(requireContext)
    };
    requireAll(req);

    4:在main.js中引用

     5:修改vue.config.js里面的配置,找到chainWebpack 属性:代码如下

    //3.0版本
      chainWebpack: config => {
        const svgRule = config.module.rule('svg')
        // 清除已有的所有 loader。
        // 如果你不这样做,接下来的 loader 会附加在该规则现有的 loader 之后。
        svgRule.uses.clear()
        svgRule
          .test(/.svg$/)
          .include.add(path.resolve(__dirname, './src/icons'))
          .end()
          .use('svg-sprite-loader')
          .loader('svg-sprite-loader')
          .options({
            symbolId: 'icon-[name]'
          })
        const fileRule = config.module.rule('file')
        fileRule.uses.clear()
        fileRule
          .test(/.svg$/)
          .exclude.add(path.resolve(__dirname, './src/icons'))
          .end()
          .use('file-loader')
          .loader('file-loader')
      }

    6:使用npm命令安装依赖

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

    7:修改vue.config.js之后需要重启服务。

    之后就可以在界面中引用svg-icon组件了

     <svg-icon icon-class="你的svg文件名称" class-name="ybp-style"></svg-icon>

    这就是我的图标:

  • 相关阅读:
    Hibernate + mysql 查询伪劣时:= 出现 Space is not allowed after parameter prefix ':' MySQL异常
    Linux下使用Markdown
    第十六章:Java内存模型——Java并发编程实战
    第十五章:原子变量与非阻塞机制——Java并发编程实战
    第十四章:构建自定义的同步工具——Java并发编程实战
    第十三章:显示锁——Java并发编程实战
    访问者模式——HeadFirst设计模式学习笔记
    原型模式——HeadFirst设计模式学习笔记
    第十二章:并发程序的测试——Java并发编程实战
    备忘录模式——HeadFirst设计模式学习笔记
  • 原文地址:https://www.cnblogs.com/fanlin92/p/14661413.html
Copyright © 2011-2022 走看看