let circle = document.querySelector('circle');
circle.addEventListener('click', () => {
circle.setAttribute('fill', 'blue');
});
See the MDN docs for the <script>
element for more info, and the JavaScript docs for details on how Parcel processes JavaScript.
Raster images or other SVGs can be embedded in an SVG file using the <image>
element. Parcel recognizes the href
and xlink:href
attributes.
<image href="image.jpg" width="100" height="50" />
Parcelβs image transformer can also be used to resize and convert images by using Query parameters.
<image href="image.jpg?as=webp" width="100" height="50" />
See the Image docs for details on how Parcel processes images.
SVG files can link to other web pages or files using the <a>
element. Parcel supports the href
and xlink:href
attributes.
<a href="circle.html">
<circle cx="50" cy="40" r="35" />
</a>
While other assets referenced from an SVG file will include a content hash in their compiled filename by default, files referenced by an <a>
element will not. That's because these URLs are typically human readable, and need to have a stable name over time. Bundle naming can be overridden by Namer plugins.
Parcel supports external references via the href
and xlink:href
attributes on many other elements. See the MDN docs for more details.
<use href="fox.svg#path" stroke="red" />
<text>
<textPath href="fox.svg#path">
Quick brown fox jumps over the lazy dog.
</textPath>
</text>
External resources referenced via the url()
function in presentation attributes such as fill
, stroke
, clip-path
, and many others are also supported.
<circle
cx="50" cy="40" r="35"
fill="url(external.svg#gradient)" />
<script>
and <style>
tags with text content are also processed just like standalone files, and the generated bundles are inserted back into the SVG file. Use the type="module"
attribute as described above to enable importing other modules from an inline script.
CSS files referenced via @import
, and JavaScript referenced via import
will be bundled into the compiled SVG file. See Stylesheets and Scripts for how to reference an external file.
style
attributeThe style
attribute can be used on any SVG element to define CSS styles. Parcel will process the inline CSS, and insert the result back into the style
attribute. This includes following referenced URLs, as well as applying PostCSS plugins like autoprefixer.
<circle
cx="50" cy="40" r="35"
style="fill: url(external.svg#gradient)" />
SVG in HTML can either be referenced as an external file, or embedded directly into an HTML document.
SVG files can be referenced from HTML in several ways. The simplest is to use the <img>
element, and reference the SVG file using the src
attribute. Parcel will follow the reference and process the SVG and all of its dependencies as well.
<img src="logo.svg" alt="logo" />
This approach works great if your SVG is static. If the SVG references external resources such as other SVGs, images, fonts, stylesheets, or scripts, or contains any interactivity, it wonβt work. You also cannot alter the styling of the SVG via CSS in the HTML page or manipulate the DOM of the SVG with JavaScript, and any text in the SVG cannot be selected by the user.
The <object>
element can be used to embed an external SVG in HTML and enable external references, scripting, interactivity, and text selection. Use the data
attribute to reference the SVG file.
<object data="interactive.svg" title="Interactive SVG"></object>
This also allows you to get access to the SVG DOM via the getSVGDocument()
method on the <object>
element.
let object = document.querySelector('object');
let svg = object.getSVGDocument();
let circle = svg.querySelector('circle');
circle.setAttribute('fill', 'red');
However, SVGs embedded using the <object>
element cannot be styled by CSS on the HTML page.
SVG can be inlined into HTML directly rather than referenced as a separate file. This allows CSS on the HTML page to style the SVG elements. Parcel supports external references within embedded SVG the same way it does when the SVG is in a separate file.
<!DOCTYPE html>
<html>
<body>
<svg width="100" height="100">
<circle cx="50" cy="50" r="50" />
</svg>
<style>
circle {
fill: blue;
}
circle:hover {
fill: green;
}
</style>
</body>
</html>
SVG can be referenced from CSS files using the url()
function. As with the <img>
element, SVGs in background images do not support external resources such as stylesheets, and scripting and interactivity is disabled.
.logo {
background: url('logo.svg');
}
You can also embed small SVGs in a CSS file using data URLs. Use the data-url:
scheme to do this, and Parcel will build the SVG and inline the result into the compiled CSS. See Bundle inlining for more details.
.logo {
background: url('data-url:logo.svg');
}
SVG files can either be referenced as an external URL from JavaScript, inlined as a string, or converted to JSX for rendering in a framework like React.
Parcel supports referencing SVG files using the URL
constructor. This example uses the result to render an <img>
element using JSX. This works the same way as described in External SVG above. You can use an <object>
element instead if the SVG is interactive or has external resources.
const logo = new URL('logo.svg', import.meta.url);
export function Logo() {
return <img src={logo} alt="logo" />;
}
See URL dependencies in the JavaScript docs for more details.
SVG can be inlined as a string in JavaScript by importing it using the bundle-text:
scheme.
import svg from 'bundle-text:./logo.svg';
let logo = document.createElement('div');
logo.innerHTML = svg;
document.body.appendChild(logo);
See Bundle inlining for more details.
The @parcel/transformer-svg-react
plugin can be used to import an SVG file as a React component. This uses SVGR to transform the SVG file into JSX. It also uses SVGO to optimize the SVG to reduce file size.
This plugin is not included in the default Parcel config, so you'll need to install it and add it to your .parcelrc
.
yarn add @parcel/transformer-svg-react --dev
You can either configure your .parcelrc
to convert all SVGs to JSX, or use a named pipeline to create a URL scheme that you can reference from a JavaScript import statement. This approach allows SVG files referenced from JavaScript to be converted to JSX, but SVGs referenced elsewhere to be kept as SVG files. Use the "..."
syntax to run the default SVG transformer first before converting the SVG to JSX.
In production mode, Parcel includes optimizations to reduce the file size of your code. See Production for more details about how this works.
In production mode, Parcel automatically minifies your code to reduce the file sizes of your bundles. By default, Parcel uses SVGO to perform SVG minification.
To configure SVGO, you can create a svgo.config.json
file in your project root directory. To see all the available configuration options for SVGO, see the official documentation.