svg-inline-loader

This Webpack loader inlines SVG as module. If you use Adobe suite or Sketch to export SVGs, you will get auto-generated, unneeded crusts. This loader removes it for you, too.

安装

  1. npm install svg-inline-loader --save-dev

配置

只需加载配置对象到 module.loaders 像下面这样。

  1. {
  2. test: /\.svg$/,
  3. loader: 'svg-inline-loader'
  4. }

警告: 这个loader你应只配置一次,通过 module.loaders 或者 require('!...') 配置。 更多细节参考 #15

Query 选项

#

删除指定的标签和它的子元素,你可以指定标签通过设置 removingTags 查询多个。

默认值: removeTags: false

removingTags: [...string]

警告: 你指定 removeTags: true 时,它才会执行。

默认值: removingTags: ['title', 'desc', 'defs', 'style']

warnTags: [...string]

警告标签,例: [‘desc’, ‘defs’, ‘style’]

默认值: warnTags: []

removeSVGTagAttrs: boolean

删除 <svg />widthheight 属性。

默认值: removeSVGTagAttrs: true

removingTagAttrs: [...string]

删除内部的 <svg />的属性。

默认值: removingTagAttrs: []

warnTagAttrs: [...string]

在console发出关于内部 <svg /> 属性的警告

默认值: warnTagAttrs: []

classPrefix: boolean || string

添加一个前缀到svg文件的class,以避免碰撞。

默认值: classPrefix: false

idPrefix: boolean || string

添加一个前缀到svg文件的id,以避免碰撞。

默认值: idPrefix: false

使用示例

  1. // 使用默认 hashed prefix (__[hash:base64:7]__)
  2. var logoTwo = require('svg-inline-loader?classPrefix!./logo_two.svg');
  3. // 使用自定义字符串
  4. var logoOne = require('svg-inline-loader?classPrefix=my-prefix-!./logo_one.svg');
  5. // 使用自定义字符串和hash
  6. var logoThree = require('svg-inline-loader?classPrefix=__prefix-[sha512:hash:hex:5]__!./logo_three.svg');

hash 操作请参照 loader-utils

通过 module.loaders 优先使用:

  1. {
  2. test: /\.svg$/,
  3. loader: 'svg-inline-loader?classPrefix'
  4. }

维护人员

svg-inline-loader - 图1


Juho Vepsäläinen

svg-inline-loader - 图2


Joshua Wiens

svg-inline-loader - 图3


Kees Kluskens

svg-inline-loader - 图4


Sean Larkin