HugeIcons Pro Vue Component Library - Beautiful and customizable icons for your Vue applications
HugeIcons is a comprehensive icon library designed for modern web and mobile applications. The free package includes 4,000+ carefully crafted icons in the Stroke Rounded style, while the pro version offers over 36,000 icons across 9 unique styles.
- 4,000+ Free Icons: Extensive collection of Stroke Rounded icons covering essential UI elements, actions, and concepts
- Pixel Perfect: Every icon is crafted on a 24x24 pixel grid ensuring crisp, clear display at any size
- Customizable: Easily adjust colors, sizes, and styles to match your design needs
- Regular Updates: New icons added regularly to keep up with evolving design trends
π Looking for Pro Icons? Check out our comprehensive documentation at docs.hugeicons.com for detailed information about pro icons, styles, and advanced usage.
- What is HugeIcons?
- Features
- Installation
- Usage
- Props
- Examples
- Performance
- Troubleshooting
- Browser Support
- Related Packages
- Pro Version
- License
- Related
- π¨ Customizable colors and sizes
- πͺ TypeScript support with full type definitions
- π― Tree-shakeable for optimal bundle size
- π¦ Multiple bundle formats (ESM, CJS, UMD)
- β‘ Lightweight and optimized
- π Alternate icon support for dynamic interactions
# Using npm
npm install @hugeicons/vue @hugeicons/core-free-icons
# Using yarn
yarn add @hugeicons/vue @hugeicons/core-free-icons
# Using pnpm
pnpm add @hugeicons/vue @hugeicons/core-free-icons
# Using bun
bun add @hugeicons/vue @hugeicons/core-free-icons
<template>
<HugeiconsIcon
:icon="SearchIcon"
:size="24"
color="currentColor"
:stroke-width="1.5"
/>
</template>
<script>
import { HugeiconsIcon } from '@hugeicons/vue';
import { SearchIcon } from '@hugeicons/core-free-icons';
export default {
components: {
HugeiconsIcon
},
setup() {
return {
SearchIcon
}
}
}
</script>
Prop (in template) | Prop (in script) | Type | Default | Description |
---|---|---|---|---|
icon |
icon |
[string, Record<string, any>][] |
Required | The main icon to display (array of SVG elements and their attributes) |
size |
size |
number | string |
24 |
Icon size in pixels. Must be a positive number. String values will be parsed to numbers |
stroke-width |
strokeWidth |
number | undefined |
undefined |
Width of the icon strokes. When used with absoluteStrokeWidth , the stroke width will be automatically scaled relative to the icon size |
absolute-stroke-width |
absoluteStrokeWidth |
boolean |
false |
When true, the stroke width will be scaled relative to the icon size to maintain visual consistency across different sizes |
alt-icon |
altIcon |
[string, Record<string, any>][] |
undefined |
Alternative icon that can be used for states, interactions, or animations |
show-alt |
showAlt |
boolean |
false |
When true, displays the altIcon instead of the main icon |
color |
color |
string |
currentColor |
Icon color (CSS color value) |
Note:
- The component accepts all standard SVG attributes as props which will be passed to the root SVG element.
- The
size
prop accepts both numbers and strings, but strings will be parsed to numbers and must result in a positive number. - Icon arrays are tuples of
[elementName: string, attributes: Record<string, any>][]
representing SVG elements.
<template>
<HugeiconsIcon :icon="SearchIcon" />
</template>
<script>
import { HugeiconsIcon } from '@hugeicons/vue';
import { SearchIcon } from '@hugeicons/core-free-icons';
export default {
components: { HugeiconsIcon },
setup() {
return { SearchIcon }
}
}
</script>
<template>
<HugeiconsIcon
:icon="NotificationIcon"
:size="32"
color="#FF5733"
/>
</template>
<script>
import { HugeiconsIcon } from '@hugeicons/vue';
import { NotificationIcon } from '@hugeicons/core-free-icons';
export default {
components: { HugeiconsIcon },
setup() {
return { NotificationIcon }
}
}
</script>
<template>
<div>
<input
v-model="searchValue"
type="text"
placeholder="Search..."
/>
<HugeiconsIcon
:icon="SearchIcon"
:alt-icon="CloseCircleIcon"
:show-alt="searchValue.length > 0"
@click="clearSearch"
/>
</div>
</template>
<script>
import { ref } from 'vue';
import { HugeiconsIcon } from '@hugeicons/vue';
import { SearchIcon, CloseCircleIcon } from '@hugeicons/core-free-icons';
export default {
components: { HugeiconsIcon },
setup() {
const searchValue = ref('');
const clearSearch = () => {
if (searchValue.value.length > 0) {
searchValue.value = '';
}
};
return {
searchValue,
clearSearch,
SearchIcon,
CloseCircleIcon
}
}
}
</script>
<template>
<button @click="toggleTheme">
<HugeiconsIcon
:icon="SunIcon"
:alt-icon="MoonIcon"
:show-alt="isDark"
/>
</button>
</template>
<script>
import { ref } from 'vue';
import { HugeiconsIcon } from '@hugeicons/vue';
import { SunIcon, MoonIcon } from '@hugeicons/core-free-icons';
export default {
components: { HugeiconsIcon },
setup() {
const isDark = ref(false);
const toggleTheme = () => isDark.value = !isDark.value;
return {
isDark,
toggleTheme,
SunIcon,
MoonIcon
}
}
}
</script>
- Tree-shaking: The package is fully tree-shakeable, ensuring only the icons you use are included in your final bundle
- Optimized SVGs: All icons are optimized for size and performance
- Code Splitting: Icons can be easily code-split when using dynamic imports
-
Icons not showing up?
- Make sure you've installed both
@hugeicons/vue
and@hugeicons/core-free-icons
- Check that the icon names are correctly imported
- Make sure you've installed both
-
TypeScript errors?
- Ensure your
tsconfig.json
includes the necessary type definitions - Check that you're using the latest version of the package
- Ensure your
-
Bundle size concerns?
- Use named imports instead of importing the entire icon set
- Implement code splitting for different sections of your app
The library supports all modern browsers.
- @hugeicons/react - React component
- @hugeicons/svelte - Svelte component
- @hugeicons/angular - Angular component
- @hugeicons/react-native - React Native component
π Want access to 36,000+ icons and 9 unique styles? Check out our Pro Version and visit docs.hugeicons.com for comprehensive documentation.
- Stroke Styles
- Stroke Rounded (
@hugeicons-pro/core-stroke-rounded
) - Stroke Sharp (
@hugeicons-pro/core-stroke-sharp
) - Stroke Standard (
@hugeicons-pro/core-stroke-standard
)
- Stroke Rounded (
- Solid Styles
- Solid Rounded (
@hugeicons-pro/core-solid-rounded
) - Solid Sharp (
@hugeicons-pro/core-solid-sharp
) - Solid Standard (
@hugeicons-pro/core-solid-standard
)
- Solid Rounded (
- Special Styles
- Bulk Rounded (
@hugeicons-pro/core-bulk-rounded
) - Duotone Rounded (
@hugeicons-pro/core-duotone-rounded
) - Twotone Rounded (
@hugeicons-pro/core-twotone-rounded
)
- Bulk Rounded (
This project is licensed under the MIT License.
- @hugeicons/core-free-icons - Free icon package
- HugeIcons Website - Browse all available icons
- Added
absoluteStrokeWidth
prop for consistent stroke width scaling - Improved stroke width handling by applying it at the SVG level
- Enhanced TypeScript types and documentation
- Initial release
- Basic icon rendering functionality
- Support for customization (size, color, alternate icons)
- Full TypeScript support