zoukankan      html  css  js  c++  java
  • 18、vue-cli3引入封装svg图标

    svg图标放大不失真,png会出现失真现象。

    一、方法一

    1、在对应vue项目里添加插件

    vue add svg-sprite

    输入 Y

    2、再执行

    npm install svgo svgo-loader --save-dev

    然后你就会看到 自动新增 的根目录文件vue.config.js和src/components/SvgIcon.vue,如图:

    vue.config.js

    vue.config.js

    3、在main.js里注册SvgIcon组件

    //引入svg组件
    import SvgIcon from '@/components/SvgIcon.vue'    
    
    //全局注册icon-svg
    Vue.component('SvgIcon', SvgIcon)
    

    4、再在assets下创建icons文件夹,将所有的svg图标放进去,name就是svg的名字,例如

    <svg-icon name="test"></svg-icon>
    

    如果项目不能成功显示SVG,可以尝试重新启动项目。

    二、方法二

    方法二需要自己配置,有些麻烦

    1、在 src/components/ 下创建 SvgIcon 组件

    SvgIcon

    <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>
    
    

    2、在 src/ 下创建一个 icons 目录,目录结构如下:

    SvgIcon

    svg 目录主要用于存放 svg 文件,来看一下 index.js 的内容,功能就是把组件注册到全局,方便使用:

    import Vue from 'vue'
    import SvgIcon from '@/components/SvgIcon'// svg组件
    
    // register globally 注册到全局
    Vue.component('svg-icon', SvgIcon)
    
    const req = require.context('./svg', false, /.svg$/)
    const requireAll = requireContext => requireContext.keys().map(requireContext)
    requireAll(req)
    

    当然,如果你有自己的想法或需求,可以单独引入,无需非要注册到全局。

    3、 在 main.js 中引入

    import './icons' // icon
    

    4 、修改默认的 loader

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

    大家可以去vue-cli3官网去查看具体教程,这里我只说需要修改的 loader 以及具体的代码实现。

    首先需要注意的是,通过 vue-cli3 构建的项目可以初始化进行很多选择,我构建的目录更多的是以 *.config.js 的形式存在的。

    在根目录下创建一个名为 vue.config.js 文件,接下来的操作都和它有关,先来看一下它完整的代码:

    module.exports = {
        chainWebpack: config => {
        // 一个规则里的 基础Loader
        // svg是个基础loader
        const svgRule = config.module.rule('svg')
    
        // 清除已有的所有 loader。
        // 如果你不这样做,接下来的 loader 会附加在该规则现有的 loader 之后。
        svgRule.uses.clear()
    
        // 添加要替换的 loader
        svgRule
          .use('svg-sprite-loader')
          .loader('svg-sprite-loader')
          .options({
            symbolId: 'icon-[name]'
          })
      }
    }
    

    SvgIcon

    使用

    SvgIcon

    abc是文件名,在icons/svg中存放svg文件

    <svg-icon icon-class="abc" />
    
    如果项目不能成功显示SVG,可以尝试重新启动项目。
  • 相关阅读:
    为什么byte取值负128到127.md
    傻傻分不清?Integer、new Integer() 和 int 的面试题
    Spring 面试 7 大问题,你顶得住不?
    消息中间件ActiveMQ、RabbitMQ、RocketMQ、ZeroMQ、Kafka如何选型?
    poj 3684 Physics Experiment(数学,物理)
    poj 3320 Jessica's Reading Problem(尺取法)
    java面试
    nyoj 234 吃土豆
    Web 通信 之 长连接、长轮询(long polling)
    XHTML使用规范
  • 原文地址:https://www.cnblogs.com/zhongchao666/p/11670345.html
Copyright © 2011-2022 走看看