Skip to content
Convert inline SVGs to standalone SVG image files without loosing styles
JavaScript HTML CSS
Branch: master
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
lib/FileSaver.js
src
.gitignore
Gruntfile.js
LICENSE.md
README.md
package.json
svg2img.js
svg2img.min.js

README.md

jQuery Plugin svg2img

The aim of this small jQuery plugin is to easy convert inline SVGs to standalone SVG image files without loosing styles:

jQuery('#example-graph').svg2img();

There is one default option - you can redeclare it in the same way:

jQuery.fn.svg2img.defaults = {
    debug: false // write debug information to console
};

You can also set the debug option at runtime:

$('#example-graph').svg2img({debug:true})

You can download all SVGs from one page by setting the selector to the document, body or svg - as you like it. There is no need for a each() call, svg2img works on the whole selection and is chainable:

$("svg").svg2img().css("border","1px solid red");

If you want to use an anchor to download the images, then it is a good idea to prevent the default action like so:

Download
<a href="" onclick="event.preventDefault(); $('#example-graph').svg2img();">SVG file</a>.

There is a online demo available.

One last thing: Safari has currently (as of this writing) problems with the underlaying savAs() implementation and tries to open the images in a new tab with or without success. See also this issue.

UPDATE 2017-04-14: After update to macOS Sierra 10.12.4 Safari 10.1 works also - but is as slow as before - collecting CSS styles runs on my MacBook 2800ms in Safari, 20ms in Google Chrome :-(
I stopped to support other image formats then SVG since the canvas export behind the scenes was not really working in too many browsers and the core feature was and is to convert inline SVGs to standalone SVG images.

You can’t perform that action at this time.