Cumulative Release v4.19.0
- v4.19.1
🔥 CHANGES (inlining SVG)
- Inline
<img src="icon.svg">
:- OLD: replaces
<img>
with<svg>
tag - NEW: inline SVG as base64-encoded data URL. Use new
svg.inline.embed = true
option to keep old behavior.
- OLD: replaces
- Encoding of data URL:
- OLD: defaults, escaped URL (
#%
chars only), e.g....
- full escaped URL, e.g.
..."/> <img src="./icon.svg?inline=escape"/> --> <img src="data:image/svg+xml,%3Csvg%20...%2F%3E"/>
-
Added support the
?embed
URL query to replace<img>
with<svg>
tag kipping img attributes:<img class="icon" src="./icon.svg?embed"/>
Result:
<svg class="icon" ...>...</svg>
-
When inlining SVG as a data URL, consider Webpack's
generator.dataUrl()
andgenerator.dataUrl.encoding
options. -
Display a warning when used
?embed
URL query for SVG files in JS or CSS. -
New
svg
plugin option:type SvgOptions = { enabled?: boolean; // RegEx to match SVG files. // Defaults `/\.svg/i`. test?: RegExp; inline?: { // Enable inline SVG by replacing <img> with <svg>, only in HTML. // Equivalent to query: `?inline=embed` | `?embed`. // Defaults `false`. embed?: boolean; // Data URL encoding, overrides `generator.dataUrl.encoding` option. // Equivalent to query: `?inline=base64` | `?inline=escape`. // Defaults the `generator.dataUrl.encoding` option, if undefined then `base64`. encoding?: 'base64' | false; }; };
Bug Fixes
- The option
js.chunkFilename
should default tojs.filename
whenjs.filename
is specified as a string, #164.