Webpack loader for generating external svg symbol sprite files, inspired by https://github.com/vadymshymko/svg-sprite-generation-loader
- Currently you have to restart your webpacker after you've added or removed a SVG,
- Caching is currently disabled (perhaps related to previous bullet).
@nerdsandcompany/webpack-sprite-svg-loader is a webpack-loader that takes a multiple svg files, transform (parse and return as an object with symbolId
and attributes
keys) and put them back in one file.
Input multiple svg files, e.g:
<!-- file1.svg -->
<svg viewBox="0 0 10 10">
<!-- file1.svg content -->
</svg>
<!-- file2.svg -->
<svg viewBox="0 0 10 30">
<!-- file2.svg content -->
</svg>
<!-- file3.svg -->
<svg viewBox="0 0 15 40">
<!-- file3.svg content -->
</svg>
Output one svg file (svg sprite):
<svg xmlns="http://www.w3.org/2000/svg">
<symbol viewBox="0 0 10 10" id="file1">
<!-- file1.svg content -->
</symbol>
<symbol viewBox="0 0 10 30" id="file2">
<!-- file1.svg content -->
</symbol>
<symbol viewBox="0 0 15 40" id="file3">
<!-- file3.svg content -->
</symbol>
</svg>
You can refer to this file to display all your icons using SVG stacking technique
npm install @nerdsandcompany/webpack-sprite-svg-loader --save-dev
yarn
yarn add @nerdsandcompany/webpack-sprite-svg-loader --dev
In your webpack config:
const path = require('path');
const glob = require('glob');
const WebpackSpriteSvgLoaderState = require('@nerdsandcompany/webpack-sprite-svg-loader/src/plugin.js');
module.exports = {
entry: {
sprite: glob.sync(path.resolve(__dirname, './src/assets/img/sprite/**/*.svg'))
},
module: {
rules: [
{
test: /\.svg$/,
use: '@nerdsandcompany/webpack-sprite-svg-loader',
options: {
spriteFilename: 'assets/img/sprite.svg'
}
},
],
},
plugins: [new WebpackSpriteSvgLoaderState()]
};
TODO: test the options and write docs