vue2.x封装svg组件并使用

第一步:安装svg-sprite-loader插件




npm install -S svg-sprite-loader
yarn add --dev svg-sprite-loader

第二步:封装svg组件


 

 

第三步:将需要的svg图标放入目录中

vue2.x封装svg组件并使用_第1张图片

第四步:配置

可在webpack.config.js或vue.config.js中配置,若项目根目录下没有vue.config.js,则手动创建一个vue.config.js,将下列代码直接粘贴进去即可

const path = require('path')
const webpack = require('webpack')

function resolve (dir) {
  return path.join(__dirname, dir)
}


module.exports = {
  chainWebpack (config) {
    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()
  }
}

第五步:全局注册

在icons目录中创建index.js文件

vue2.x封装svg组件并使用_第2张图片

  index.js中内容如下

import Vue from 'vue'
import SvgIcon from '../../components/svgIcon'// svg component
 
// register globally
Vue.component('svg-icon', SvgIcon)
 
const req = require.context('./svg', false, /\.svg$/)
const requireAll = requireContext => requireContext.keys().map(requireContext)
requireAll(req)

第六步:在main.js中全局引入

import './assets/icons/index'

第七步:使用

代码如下:




效果如下

vue2.x封装svg组件并使用_第3张图片

 注意:若未显示出图标请重新运行项目。

运行后如果还未显示请检查相应地方的引入路径是否正确,尤其是vue.config.js中的路径。

你可能感兴趣的:(前端,vue.js,svg)