Iconify icon components

Iconify offers components for several popular frameworks:

If you are using framework not listed above, you can use web component that works with all modern frameworks. Web component is also preferred if you are using server side rendering.

Source independent

Unlike icon fonts, which only render icons available in specific fonts, Iconify icon components are not tied to specific icon set.

API support

All icon components rely on Iconify API to dynamically load icon data as needed.

They fetch icons as needed from Iconify API, so developers do not need to create icon bundles and visitors don't need to load icons that are not rendered. Because of this, Iconify icon components are very easy to use. Developers do not need to keep track of icons used in project.

There are several downsides to using API:

  • API requires visitor to be online. Iconify API software is available, so organizations can mitigate it by hosting Iconify API on internal servers. You can also create icon bundles.
  • Code is a bit bigger because it includes API support. Difference isn't big, just about 10-15kb.

Usage without API

If you want to make sure icon data is always available and component is usable offline, do not rely on Iconify API. Even though Iconify API servers have redundancies built in to provide as stable experience as possible, internet is never 100% reliable.

SVG framework and all components have alternative bundles without API support. They rely on developer providing icon data. They are a bit harder to work with because you need to bundle icon data with package. These components get icon data from individual icon packages and icon bundles.

Components vs SVG Framework

Unlike SVG framework, other icon components are designed for specific component frameworks:

  • Components use syntax familiar to developers.
  • Components use framework's native code to render icons.
  • Most components correctly bind event handlers and dynamic properties. SVG framework cannot do that.
  • Components render icons regardless of parent element, making it perfect for use in things like Shadow DOM. SVG framework only scans placeholders in document.body (unless configured otherwise, but components do that without additional configuration).


All icon components share common code, making it easy to maintain multiple icon components for multiple frameworks and provide identical functionality.

You can find code and demo files in big monorepo: https://github.com/iconify/iconify.