dom2svg
TypeScript icon, indicating that this package has built-in type declarations

1.0.6 • Public • Published

dom2svg

Version Downloads Issues License

Library to convert a given HTML DOM node into an accessible SVG "screenshot".

Fork from dom-to-svg

English | 简体中文

Install

pnpm/npm/yarn i dom2svg

Usage

import { documentToSVG, elementToSVG, formatXML, inlineResources } from 'dom2svg'

// Capture the whole document
const svgDocument = documentToSVG(document)

// Capture specific element
const svgDocument = elementToSVG(document.querySelector('#my-element'))

// Inline external resources (fonts, images, etc) as data: URIs
await inlineResources(svgDocument.documentElement)

// Get SVG string
const svgString = new XMLSerializer().serializeToString(svgDocument)

The output can be used as-is as valid SVG or easily passed to other packages to pretty-print or compress.

Features

  • Does NOT rely on <foreignObject> - SVGs will work in design tools like Illustrator, Figma etc.
  • Maintains DOM accessibility tree by annotating SVG with correct ARIA attributes.
  • Maintains interactive links.
  • Maintains text to allow copying to clipboard.
  • Can inline external resources like images, fonts, etc to make SVG self-contained.
  • Maintains CSS stacking order of elements.
  • Outputs debug attributes on SVG to trace elements back to their DOM nodes.

Caveats

  • Designed to run in the browser. Using JSDOM on the server will likely not work, but it can easily run inside Puppeteer.

Package Sidebar

Install

npm i dom2svg

Weekly Downloads

53

Version

1.0.6

License

MIT

Unpacked Size

75.8 kB

Total Files

7

Last publish

Collaborators

  • xiashui