Convert Figma logo to code with AI

tailwindlabs logoheroicons

A set of free MIT-licensed high-quality SVG icons for UI development.

21,500
1,278
21,500
2

Top Related Projects

24,931

Simply beautiful open-source icons

A scalable set of icons handcrafted with <3 by GitHub

The iconic SVG, font, and CSS toolkit

17,564

Premium hand-crafted icons built by Ionic, for Ionic apps and web apps everywhere 🌎

Material Design icons by Google (Material Symbols)

A set of over 5700 free MIT-licensed high-quality SVG icons for you to use in your web projects.

Quick Overview

Heroicons is a set of free, MIT-licensed high-quality SVG icons for you to use in your web projects. Created by the makers of Tailwind CSS, it offers a comprehensive collection of icons in outline and solid styles, designed to be easily customizable and integrated into various web development workflows.

Pros

  • Large collection of well-designed, consistent icons
  • Available in both outline and solid styles
  • Easy to use and customize with CSS
  • Regularly updated with new icons

Cons

  • Limited to two styles (outline and solid)
  • May not have every specific icon needed for niche projects
  • Requires additional setup for React or Vue integration
  • File size can be an issue if using many icons

Code Examples

  1. Using Heroicons in HTML:
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor" class="w-6 h-6">
  <path stroke-linecap="round" stroke-linejoin="round" d="M6 18L18 6M6 6l12 12" />
</svg>
  1. Using Heroicons with React:
import { BeakerIcon } from '@heroicons/react/24/solid'

function MyComponent() {
  return (
    <div>
      <BeakerIcon className="h-6 w-6 text-blue-500" />
      <p>...</p>
    </div>
  )
}
  1. Customizing Heroicons with CSS:
<style>
  .icon-large {
    width: 3rem;
    height: 3rem;
    stroke: #4a5568;
    stroke-width: 1;
  }
</style>

<svg class="icon-large" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="currentColor">
  <path stroke-linecap="round" stroke-linejoin="round" d="M5 13l4 4L19 7" />
</svg>

Getting Started

To use Heroicons in your project:

  1. Visit the Heroicons website
  2. Browse and select the icon you want to use
  3. Copy the SVG code for the selected icon
  4. Paste the SVG code into your HTML

For React or Vue projects, install the package:

npm install @heroicons/react
# or
yarn add @heroicons/react

Then import and use the icons in your components as shown in the React example above.

Competitor Comparisons

24,931

Simply beautiful open-source icons

Pros of Feather

  • Larger icon set with over 280 icons compared to Heroicons' 220+
  • Simpler and more minimalistic design style
  • Available in multiple file formats (SVG, PNG, and icon font)

Cons of Feather

  • Less frequent updates and maintenance
  • Fewer customization options out of the box
  • Limited to a single weight (regular), while Heroicons offers solid and outline variants

Code Comparison

Feather usage:

<i data-feather="circle"></i>
<script>
  feather.replace()
</script>

Heroicons usage:

<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor" class="w-6 h-6">
  <path stroke-linecap="round" stroke-linejoin="round" d="M12 ..." />
</svg>

Both libraries offer easy integration, but Feather requires a JavaScript call to replace icons, while Heroicons can be used directly as inline SVGs. Heroicons provides more flexibility in terms of styling and customization within the SVG structure.

A scalable set of icons handcrafted with <3 by GitHub

Pros of Octicons

  • Larger icon set with over 500 icons
  • Tighter integration with GitHub's design system
  • Multiple file formats available (SVG, PNG, WebFont)

Cons of Octicons

  • Less customization options for individual icons
  • Primarily designed for GitHub's ecosystem, may not fit all projects
  • Slightly more complex implementation process

Code Comparison

Heroicons usage:

<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="currentColor">
  <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 6v6m0 0v6m0-6h6m-6 0H6" />
</svg>

Octicons usage:

<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" width="16" height="16">
  <path fill-rule="evenodd" d="M8 2a.75.75 0 01.75.75v4.5h4.5a.75.75 0 010 1.5h-4.5v4.5a.75.75 0 01-1.5 0v-4.5h-4.5a.75.75 0 010-1.5h4.5v-4.5A.75.75 0 018 2z"/>
</svg>

Both repositories offer high-quality, open-source icon sets for web projects. Heroicons focuses on simplicity and ease of use, while Octicons provides a more extensive set of icons tailored for GitHub's design language. Choose based on your project's specific needs and design preferences.

The iconic SVG, font, and CSS toolkit

Pros of Font-Awesome

  • Larger icon library with over 7,000 icons
  • Includes both free and paid premium icons
  • Supports multiple file formats (SVG, webfonts, etc.)

Cons of Font-Awesome

  • Larger file size due to extensive icon set
  • Steeper learning curve for implementation
  • Some advanced features require paid plans

Code Comparison

Font-Awesome (using webfont):

<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.3/css/all.min.css">
<i class="fas fa-user"></i>

Heroicons (using SVG):

<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="currentColor">
  <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z" />
</svg>

Summary

Font-Awesome offers a vast icon library with multiple format options, making it suitable for various projects. However, it comes with a larger file size and potential complexity. Heroicons provides a simpler, more focused set of SVG icons, which can be easier to implement and customize but may have limited options compared to Font-Awesome's extensive collection.

17,564

Premium hand-crafted icons built by Ionic, for Ionic apps and web apps everywhere 🌎

Pros of Ionicons

  • Larger icon set with over 1,200 icons compared to Heroicons' 450+
  • Supports multiple icon styles (outline, filled, sharp) for greater versatility
  • Includes a custom SVG icon framework for easier integration and manipulation

Cons of Ionicons

  • Larger file size due to the extensive icon set, potentially impacting load times
  • Less focused on minimalist design, which may not suit all projects
  • Steeper learning curve for utilizing the custom SVG framework

Code Comparison

Heroicons usage:

<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="currentColor">
  <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 6v6m0 0v6m0-6h6m-6 0H6" />
</svg>

Ionicons usage:

<ion-icon name="add-outline"></ion-icon>

Both libraries offer easy-to-use icon implementations, but Ionicons provides a more concise syntax through its custom elements. Heroicons relies on standard SVG markup, offering more direct control over icon properties.

While Heroicons focuses on a curated set of essential icons with a consistent style, Ionicons provides a broader range of options and styles to choose from. The choice between the two depends on project requirements, design preferences, and performance considerations.

Material Design icons by Google (Material Symbols)

Pros of Material Design Icons

  • Extensive library with over 2,000 icons in various styles and themes
  • Consistent design language aligned with Google's Material Design principles
  • Available in multiple formats (SVG, PNG, font) for versatile usage

Cons of Material Design Icons

  • Larger file size due to the extensive collection, potentially impacting load times
  • Less frequent updates compared to Heroicons
  • May require additional setup or dependencies for optimal usage in some frameworks

Code Comparison

Material Design Icons:

<link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet">
<i class="material-icons">favorite</i>

Heroicons:

<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="currentColor">
  <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4.318 6.318a4.5 4.5 0 000 6.364L12 20.364l7.682-7.682a4.5 4.5 0 00-6.364-6.364L12 7.636l-1.318-1.318a4.5 4.5 0 00-6.364 0z" />
</svg>

Summary

Material Design Icons offers a vast collection of icons with a consistent design language, while Heroicons provides a more streamlined and easily customizable set. The choice between the two depends on project requirements, design preferences, and performance considerations.

A set of over 5700 free MIT-licensed high-quality SVG icons for you to use in your web projects.

Pros of Tabler Icons

  • Larger icon set with over 3,400 icons compared to Heroicons' 450+
  • Offers multiple styles (outline, filled, and more) for each icon
  • Provides SVG sprite option for easier implementation

Cons of Tabler Icons

  • Less integration with Tailwind CSS framework
  • May have inconsistencies in design due to the larger set
  • Potentially slower load times due to the larger library size

Code Comparison

Heroicons usage:

<svg class="h-6 w-6 text-gray-500" fill="none" viewBox="0 0 24 24" stroke="currentColor">
  <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4 6h16M4 12h16M4 18h16" />
</svg>

Tabler Icons usage:

<svg xmlns="http://www.w3.org/2000/svg" class="icon icon-tabler icon-tabler-menu-2" width="24" height="24" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round">
  <path stroke="none" d="M0 0h24v24H0z" fill="none"/>
  <line x1="4" y1="6" x2="20" y2="6" />
  <line x1="4" y1="12" x2="20" y2="12" />
  <line x1="4" y1="18" x2="20" y2="18" />
</svg>

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

Heroicons

Beautiful hand-crafted SVG icons, by the makers of Tailwind CSS.
Available as basic SVG icons and via first-party React and Vue libraries.

Browse at Heroicons.com →

Latest Release License

Basic Usage

The quickest way to use these icons is to simply copy the source for the icon you need from heroicons.com and inline it directly into your HTML:

<svg
  class="size-6 text-gray-500"
  fill="none"
  viewBox="0 0 24 24"
  stroke="currentColor"
  stroke-width="2"
>
  <path
    stroke-linecap="round"
    stroke-linejoin="round"
    d="M12 8v4l3 3m6-3a9 9 0 11-18 0 9 9 0 0118 0z"
  />
</svg>

Both icon styles are preconfigured to be stylable by setting the color CSS property, either manually or using utility classes like text-gray-500 in a framework like Tailwind CSS.

React

First, install @heroicons/react from npm:

npm install @heroicons/react

Now each icon can be imported individually as a React component:

import { BeakerIcon } from '@heroicons/react/24/solid'

function MyComponent() {
  return (
    <div>
      <BeakerIcon className="size-6 text-blue-500" />
      <p>...</p>
    </div>
  )
}

The 24x24 outline icons can be imported from @heroicons/react/24/outline, the 24x24 solid icons can be imported from @heroicons/react/24/solid, the 20x20 solid icons can be imported from @heroicons/react/20/solid, and 16x16 solid icons can be imported from @heroicons/react/16/solid.

Icons use an upper camel case naming convention and are always suffixed with the word Icon.

Browse the full list of icon names on UNPKG →

Vue

First, install @heroicons/vue from npm:

npm install @heroicons/vue

Now each icon can be imported individually as a Vue component:

<template>
  <div>
    <BeakerIcon class="size-6 text-blue-500" />
    <p>...</p>
  </div>
</template>

<script setup>
import { BeakerIcon } from '@heroicons/vue/24/solid'
</script>

The 24x24 outline icons can be imported from @heroicons/vue/24/outline, the 24x24 solid icons can be imported from @heroicons/vue/24/solid, the 20x20 solid icons can be imported from @heroicons/vue/20/solid, and the 16x16 solid icons can be imported from @heroicons/vue/16/solid.

Icons use an upper camel case naming convention and are always suffixed with the word Icon.

Browse the full list of icon names on UNPKG →

Contributing

While we absolutely appreciate anyone's willingness to try and improve the project, we're currently only interested in contributions that fix bugs, for example things like incorrect TypeScript types, or fixing an icon that's been exported with a fill instead of a stroke, etc.

We're not accepting contributions for new icons or adding support for other frameworks like Svelte or SolidJS. Instead we encourage you to release your own icons in your own library, and create your own packages for any other frameworks you'd like to see supported.

License

This library is MIT licensed.

NPM DownloadsLast 30 Days