Skip to content

Getting Started

Overview

vite-plugin-svg-icons-ng is a high-performance SVG icon plugin built for Vite.

It automatically generates SVG sprites from local files and injects them at runtime, allowing you to use SVG icons as easily as regular icons.

No manual sprite management, no extra requests, and no complex setup—just a clean and reusable icon system.

What you get

  • File-based icon input, auto-generated SVG sprite output.
  • Runtime injection with no extra network request.
  • Stable behavior across dev, build, and SSR flows.
  • Built-in cache + HMR for a smoother icon iteration loop.

If you want the background story, read Why This Plugin.

Quick Start

Step 1: Install

sh
pnpm add -D vite-plugin-svg-icons-ng
sh
npm i -D vite-plugin-svg-icons-ng
sh
yarn add -D vite-plugin-svg-icons-ng

Step 2: Configure plugin

Add createSvgIconsPlugin in vite.config.ts / vite.config.js:

ts
import { createSvgIconsPlugin } from 'vite-plugin-svg-icons-ng'
import path from 'node:path'

export default defineConfig({
  plugins: [
    createSvgIconsPlugin({
      iconDirs: [path.resolve(process.cwd(), 'src/icons')],
    }),
  ],
})

At this point, the SVG sprite has already been generated and injected into the DOM.

Step 3: Continue

  • Go to Usage to see how to use it next.
  • Check Options for plugin configuration details.