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 = trueoption 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
?embedURL 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.encodingoptions. -
Display a warning when used
?embedURL query for SVG files in JS or CSS. -
New
svgplugin 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.chunkFilenameshould default tojs.filenamewhenjs.filenameis specified as a string, #164.