svg-inline-loader
svg-inline-loader
这个 Webpack 加载器将 SVG 作为模块。如果您使用 Adobe 套件或 Sketch 来导出 SVG,您将获得自动生成的不需要的外壳。这个加载器也会为你删除它。
安装
npm install svg-inline-loader --save-dev
配置
只需加载配置对象到 module.loaders
像下面这样。
{
test: /\.svg$/,
loader: 'svg-inline-loader'
}
警告: 这个loader你应只配置一次,通过 module.loaders
或者 require('!...')
配置。 更多细节参考 #15。
查询选项
删除指定的标签和它的子元素,你可以指定标签通过设置 removingTags
查询多个。
默认: removeTags: false
removingTags: [...string]
警告: 你指定 removeTags: true
时,它才会执行。
default: removingTags: ['title', 'desc', 'defs', 'style']
warnTags: [...string]
警告标签,例如:'desc','defs','style'
default: warnTags: []
removeSVGTagAttrs: boolean
从中删除width和height属性<svg />。
默认: 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
使用示例
// Using default hashed prefix (__[hash:base64:7]__)
var logoTwo = require('svg-inline-loader?classPrefix!./logo_two.svg'
// Using custom string
var logoOne = require('svg-inline-loader?classPrefix=my-prefix-!./logo_one.svg'
// Using custom string and hash
var logoThree = require('svg-inline-loader?classPrefix=__prefix-[sha512:hash:hex:5]__!./logo_three.svg'
有关散列选项,请参阅loader-utils。
通过 module.loaders
优先使用:
{
test: /\.svg$/,
loader: 'svg-inline-loader?classPrefix'
}