2016-03-31 14:17:09 +08:00
---
category: Components
2016-11-09 14:43:32 +08:00
type: General
2016-09-08 16:53:50 +08:00
title: Icon
2016-07-26 19:45:55 +08:00
toc: false
2016-03-31 14:17:09 +08:00
---
2015-05-27 15:43:29 +08:00
2017-03-19 14:12:58 +08:00
Semantic vector graphics.
2015-06-17 19:48:17 +08:00
2016-08-20 11:58:31 +08:00
## List of icons
2015-05-27 15:43:29 +08:00
2016-03-07 11:58:14 +08:00
```__react
2018-09-01 16:16:11 +08:00
import IconDisplay from 'site/theme/template/IconDisplay';
ReactDOM.render(< IconDisplay / > , mountNode);
2016-03-07 11:58:14 +08:00
```
2017-03-19 14:12:58 +08:00
## API
2016-10-08 15:09:56 +08:00
2018-08-20 14:00:51 +08:00
| Property | Description | Type | Default |
| --- | --- | --- | --- |
2018-08-30 22:53:24 +08:00
| type | Type of the ant design icon | string | - |
2018-08-20 14:00:51 +08:00
| style | Style properties of icon, like `fontSize` and `color` | CSSProperties | - |
2019-05-07 14:57:32 +08:00
| theme | Theme of the ant design icon | 'filled' \| 'outlined' \| 'twoTone' | 'outlined' |
2018-08-20 14:00:51 +08:00
| spin | Rotate icon with animation | boolean | false |
2019-01-29 10:46:42 +08:00
| rotate | Rotate degrees (added in 3.13.0, not working in IE9) | number | - |
2018-08-20 14:00:51 +08:00
| component | The component used for the root node. This will override the ** `type` ** property. | ComponentType< CustomIconComponentProps \> | - |
2018-09-01 19:44:21 +08:00
| twoToneColor | Only support the two-tone icon. Specific the primary color. | string (hex color) | - |
2018-08-20 14:00:51 +08:00
2018-09-28 14:48:56 +08:00
### SVG icons
2018-09-16 15:09:58 +08:00
2018-09-28 14:45:35 +08:00
We introduced SVG icons in `3.9.0` version replacing font icons which brings benefits below:
2018-09-16 15:09:58 +08:00
2018-09-28 14:45:35 +08:00
- Complete offline usage of icon, no dependency of CDN font icon file and no more empty square during downloading than no need to deploy icon font files locally either.
2018-09-16 15:09:58 +08:00
- Much more display accuracy in lower-level screens.
- Support multiple colors for icon.
- No need to change built-in icons with overriding styles by providing more props in component.
2018-09-28 14:45:35 +08:00
More discussion of SVG icon reference to [#10353 ](https://github.com/ant-design/ant-design/issues/10353 ).
2018-09-16 15:09:58 +08:00
2018-09-28 14:45:35 +08:00
> ⚠️ About the extra bundle size brought by all SVG icons we imported in 3.9.0, we will provide new API to allow developers importing icons as your need, you can trace [#12011](https://github.com/ant-design/ant-design/issues/12011) for further progress.
2019-03-14 15:39:51 +08:00
>
> Before this, you can use [webpack plugin](https://github.com/Beven91/webpack-ant-icon-loader) from community to chunk the icon file.
2018-09-16 15:09:58 +08:00
2018-09-28 14:45:35 +08:00
The properties `theme` , `component` and `twoToneColor` are added in `3.9.0` . The best practice is to pass the property `theme` to every `<Icon />` components.
2018-09-01 20:37:18 +08:00
```jsx
< Icon type = "star" theme = "filled" / >
```
2018-08-20 14:00:51 +08:00
All the icons will render to `<svg>` . You can still set `style` and `className` for size and color of icons.
```jsx
2018-09-01 20:37:18 +08:00
< Icon type = "message" style = {{ fontSize: ' 16px ' , color: ' # 08c ' } } theme = "outlined" / >
2018-08-20 14:00:51 +08:00
```
2018-09-16 15:09:58 +08:00
### Set TwoTone Color
2018-09-02 19:32:01 +08:00
When using the two-tone icons, you can use the static methods `Icon.getTwoToneColor()` and `Icon.setTwoToneColor(colorString)` to spicify the primary color.
```jsx
Icon.setTwoToneColor('#eb2f96');
Icon.getTwoToneColor(); // #eb2f96
```
2018-09-21 00:00:19 +08:00
### Custom Font Icon
We added a `createFromIconfontCN` function to help developer using their own icons deployed at [iconfont.cn ](http://iconfont.cn/ ) in a convenient way.
> This method is specified for [iconfont.cn](http://iconfont.cn/).
```js
const MyIcon = Icon.createFromIconfontCN({
scriptUrl: '//at.alicdn.com/t/font_8d5l8fzk5b87iudi.js', // generated by iconfont.cn
});
ReactDOM.render(< MyIcon type = "icon-example" / > , mountedNode);
```
It create a component that uses SVG sprites in essence.
The following options are available:
| Property | Description | Type | Default |
| --- | --- | --- | --- |
| scriptUrl | The URL generated by [iconfont.cn ](http://iconfont.cn/ ) project. | string | - |
| extraCommonProps | Define extra properties to the component | `{ [key: string]: any }` | {} |
2018-09-28 14:45:35 +08:00
The property `scriptUrl` should be set to import the SVG sprite symbols.
2018-09-21 00:00:19 +08:00
See [iconfont.cn documents ](http://iconfont.cn/help/detail?spm=a313x.7781069.1998910419.15&helptype=code ) to learn about how to generate `scriptUrl` .
2018-09-28 14:45:35 +08:00
### Custom SVG Icon
2018-09-16 15:09:58 +08:00
2018-09-28 14:45:35 +08:00
You can import SVG icon as an react component by using `webpack` and [`@svgr/webpack` ](https://www.npmjs.com/package/@svgr/webpack ). `@svgr/webpack` 's `options` [reference ](https://github.com/smooth-code/svgr#options ).
2018-08-20 14:00:51 +08:00
```js
// webpack.config.js
{
test: /\.svg(\?v=\d+\.\d+\.\d+)?$/,
use: [
{
loader: 'babel-loader',
},
{
loader: '@svgr/webpack',
options: {
babel: false,
icon: true,
},
},
],
}
```
2017-04-06 20:52:32 +08:00
```jsx
2018-08-20 14:00:51 +08:00
import { Icon } from 'antd';
import MessageSvg from 'path/to/message.svg'; // path to your '*.svg' file.
2019-05-07 14:57:32 +08:00
ReactDOM.render(< Icon component = {MessageSvg} / > , mountNode);
2017-04-06 20:52:32 +08:00
```
2018-09-02 18:04:07 +08:00
The following properties are available for the component:
2018-08-20 14:00:51 +08:00
2019-05-07 14:57:32 +08:00
| Property | Description | Type | Default |
| --------- | ------------------------------------------------ | ---------------- | -------------- |
| width | The width of the `svg` element | string \| number | '1em' |
| height | The height of the `svg` element | string \| number | '1em' |
| fill | Define the color used to paint the `svg` element | string | 'currentColor' |
| className | The computed class name of the `svg` element | string | - |
| style | The computed style of the `svg` element | CSSProperties | - |