Socket
Socket
Sign inDemoInstall

svgo

Package Overview
Dependencies
16
Maintainers
4
Versions
99
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    svgo

Nodejs-based tool for optimizing SVG vector graphics files


Version published
Weekly downloads
17M
decreased by-1.15%
Maintainers
4
Install size
6.24 MB
Created
Weekly downloads
 

Package description

What is svgo?

The svgo npm package is a Node.js-based tool for optimizing SVG vector graphics files. SVGO stands for Scalable Vector Graphics Optimizer. It works by applying a series of transformations and optimizations to SVG files to reduce their size without affecting their visual quality. This is particularly useful for web development, where smaller file sizes can lead to faster load times and better performance.

What are svgo's main functionalities?

Minify SVG files

This feature allows you to minify SVG files by removing unnecessary data without affecting the rendering of the SVG. The code sample demonstrates how to use the optimize function to minify an SVG string.

const { optimize } = require('svgo');
const svgString = '<svg ...> ... </svg>';
const result = optimize(svgString, { path: 'path/to/svg/file.svg' });
console.log(result.data);

Remove specified attributes

This feature allows you to remove specified attributes from SVG elements. The code sample shows how to use the removeAttributesBySelector plugin to remove the 'fill' attribute from all elements that have it.

const { optimize } = require('svgo');
const svgString = '<svg ...> ... </svg>';
const result = optimize(svgString, {
  plugins: [
    {
      name: 'removeAttributesBySelector',
      params: {
        selector: '[fill]',
        attributes: 'fill'
      }
    }
  ]
});
console.log(result.data);

Prettify SVG files

This feature allows you to prettify SVG files by reformatting them with consistent indentation and spacing. The code sample demonstrates how to use the js2svg option with the pretty parameter set to true.

const { optimize } = require('svgo');
const svgString = '<svg ...> ... </svg>';
const result = optimize(svgString, {
  plugins: [
    'preset-default',
    'sortAttrs',
    {
      name: 'removeAttrs',
      params: { attrs: '(stroke|fill)' }
    }
  ],
  js2svg: { pretty: true }
});
console.log(result.data);

Other packages similar to svgo

Readme

Source
SVGO logo

SVGO npm version Discord

SVG Optimizer is a Node.js-based tool for optimizing SVG vector graphics files.

Why?

SVG files, especially those exported from various editors, usually contain a lot of redundant and useless information. This can include editor metadata, comments, hidden elements, default or non-optimal values and other stuff that can be safely removed or converted without affecting the SVG rendering result.

Installation

Via npm:

npm -g install svgo

Via yarn:

yarn global add svgo

CLI usage

Processing single files:

svgo one.svg two.svg -o one.min.svg two.min.svg

Processing directory of svg files, recursively using -f, --folder:

svgo -f ./path/to/folder/with/svg/files -o ./path/to/folder/with/svg/output

Help for advanced usage:

svgo --help

Configuration

SVGO has a plugin-based architecture, separate plugins allows various xml svg optimizations. See built-in plugins. SVGO automatically loads configuration from svgo.config.js or from --config ./path/myconfig.js. Some general options can be configured via CLI.

// svgo.config.js
module.exports = {
  multipass: true, // boolean. false by default
  datauri: 'enc', // 'base64' (default), 'enc' or 'unenc'.
  js2svg: {
    indent: 2, // string with spaces or number of spaces. 4 by default
    pretty: true, // boolean, false by default
  },
  plugins: [
    // set of built-in plugins enabled by default
    'preset-default',

    // enable built-in plugins by name
    'prefixIds',

    // or by expanded notation which allows to configure plugin
    {
      name: 'sortAttrs',
      params: {
        xmlnsOrder: 'alphabetical',
      },
    },
  ],
};

Default preset

When extending default configuration specify preset-default plugin to enable optimisations. Each plugin of default preset can be disabled or configured with "overrides" param.

module.exports = {
  plugins: [
    {
      name: 'preset-default',
      params: {
        overrides: {
          // customize default plugin options
          inlineStyles: {
            onlyMatchedOnce: false,
          },

          // or disable plugins
          removeDoctype: false,
        },
      },
    },
  ],
};

The default preset includes plugins marked with 'Yes' in the plugin list below.

Custom plugin

It's also possible to specify a custom plugin:

const anotherCustomPlugin = require('./another-custom-plugin.js');
module.exports = {
  plugins: [
    {
      name: 'customPluginName',
      params: {
        optionName: 'optionValue',
      },
      fn: (ast, params, info) => {},
    },
    anotherCustomPlugin,
  ],
};

API usage

SVGO provides a few low level utilities.

optimize

The core of SVGO is optimize function.

const { optimize } = require('svgo');
const result = optimize(svgString, {
  // optional but recommended field
  path: 'path-to.svg',
  // all config fields are also available here
  multipass: true,
});
const optimizedSvgString = result.data;

loadConfig

If you write a tool on top of SVGO you might need a way to load SVGO config.

const { loadConfig } = require('svgo');
const config = await loadConfig();

You can also specify a relative or absolute path and customize the current working directory.

const config = await loadConfig(configFile, cwd);

Troubleshooting

SVG won't scale when CSS is applied on it.

Observed Problem: I'm using my SVG files on a website. It looks like the rendered SVG doesn't scale when the dimensions are altered using CSS.

Possible Solution: Try disabling removeViewBox in the configuration. See issue #1128 for details and discussion.

Built-in plugins

PluginDescriptionDefault
addAttributesToSVGElementadds attributes to an outer <svg> element
addClassesToSVGElementadd classnames to an outer <svg> element
cleanupAttrscleanup attributes from newlines, trailing, and repeating spacesYes
cleanupEnableBackgroundremove or cleanup enable-background attribute when possibleYes
cleanupIdsremove unused and minify used IDsYes
cleanupListOfValuesround numeric values in attributes that take a list of numbers (like viewBox or enable-background)
cleanupNumericValuesround numeric values to the fixed precision, remove default px unitsYes
collapseGroupscollapse useless groupsYes
convertColorsconvert colors (from rgb() to #rrggbb, from #rrggbb to #rgb)Yes
convertEllipseToCircleconvert non-eccentric <ellipse> to <circle>Yes
convertOneStopGradientsconverts one-stop (single color) gradients to a plain color
convertPathDataconvert Path data to relative or absolute (whichever is shorter), convert one segment to another, trim useless delimiters, smart rounding, and much moreYes
convertShapeToPathconvert some basic shapes to <path>Yes
convertStyleToAttrsconvert styles into attributes
convertTransformcollapse multiple transforms into one, convert matrices to the short aliases, and much moreYes
inlineStylesmove and merge styles from <style> elements to element style attributesYes
mergePathsmerge multiple Paths into oneYes
mergeStylesmerge multiple style elements into oneYes
minifyStylesminify <style> elements content with CSSOYes
moveElemsAttrsToGroupmove elements' attributes to their enclosing groupYes
moveGroupAttrsToElemsmove some group attributes to the contained elementsYes
prefixIdsprefix IDs and classes with the SVG filename or an arbitrary string
removeAttributesBySelectorremoves attributes of elements that match a CSS selector
removeAttrsremove attributes by pattern
removeCommentsremove commentsYes
removeDescremove <desc>Yes
removeDimensionsremove width/height and add viewBox if it's missing (opposite to removeViewBox, disable it first)
removeDoctyperemove doctype declarationYes
removeEditorsNSDataremove editors namespaces, elements, and attributesYes
removeElementsByAttrremove arbitrary elements by ID or className
removeEmptyAttrsremove empty attributesYes
removeEmptyContainersremove empty Container elementsYes
removeEmptyTextremove empty Text elementsYes
removeHiddenElemsremove hidden elementsYes
removeMetadataremove <metadata>Yes
removeNonInheritableGroupAttrsremove non-inheritable group's "presentation" attributesYes
removeOffCanvasPathsremoves elements that are drawn outside of the viewbox
removeRasterImagesremove raster images
removeScriptElementremove scripts
removeStyleElementremove <style> elements
removeTitleremove <title>Yes
removeUnknownsAndDefaultsremove unknown elements content and attributes, remove attributes with default valuesYes
removeUnusedNSremove unused namespaces declarationYes
removeUselessDefsremove elements of <defs> without idYes
removeUselessStrokeAndFillremove useless stroke and fill attributesYes
removeViewBoxremove viewBox attribute when possibleYes
removeXMLNSremoves the xmlns attribute (for inline SVG)
removeXMLProcInstremove XML processing instructionsYes
reusePathsFind duplicated elements and replace them with links
sortAttrssort element attributes for epic readabilityYes
sortDefsChildrensort children of <defs> in order to improve compressionYes

Other ways to use SVGO

MethodReference
Web appSVGOMG
GitHub ActionSVGO Action
Grunt taskgrunt-svgmin
Gulp taskgulp-svgmin
Mimosa modulemimosa-minify-svg
OSX Folder Actionsvgo-osx-folder-action
Webpack loaderimage-minimizer-webpack-plugin
Telegram Botsvgo_bot
PostCSS pluginpostcss-svgo
Inkscape plugininkscape-svgo
Sketch pluginsvgo-compressor
macOS appImage Shrinker
Rollup pluginrollup-plugin-svgo
VS Code pluginvscode-svgo
Atom pluginatom-svgo
Sublime pluginSublime-svgo
Figma pluginAdvanced SVG Export
Linux appOh My SVG
Browser extensionSVG Gobbler
APIVector Express

Donors

SheetJS LLCFontello

This software is released under the terms of the MIT license.

Logo by André Castillo.

Keywords

FAQs

Last updated on 08 Nov 2023

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc