--- category: Components type: General title: Icon toc: false --- Semantic vector graphics. ## List of icons > Click the icon and copy the code. We are still adding two-tone icons right now. ```__react import IconDisplay from 'site/theme/template/IconDisplay'; ReactDOM.render(, mountNode); ``` ## API | Property | Description | Type | Default | | --- | --- | --- | --- | | type | Type of the ant design icon | string | - | | style | Style properties of icon, like `fontSize` and `color` | CSSProperties | - | | theme | Theme of the ant design icon | 'filled' \| 'outlined' \| 'twoTone' | 'outlined' | | spin | Rotate icon with animation | boolean | false | | component | The component used for the root node. This will override the **`type`** property. | ComponentType | - | | twoToneColor | Only support the two-tone icon. Specific the primary color. | string (hex color) | - | The properties `theme`, `component` and `twoToneColor` are added in `antd@3.9.x`. The best practice is to pass the property `theme` to every `` components. ```jsx ``` All the icons will render to ``. You can still set `style` and `className` for size and color of icons. ```jsx ``` 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 ``` 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). ```js // webpack.config.js { test: /\.svg(\?v=\d+\.\d+\.\d+)?$/, use: [ { loader: 'babel-loader', }, { loader: '@svgr/webpack', options: { babel: false, icon: true, }, }, ], } ``` ```jsx import { Icon } from 'antd'; import MessageSvg from 'path/to/message.svg'; // path to your '*.svg' file. ReactDOM.render( , mountNode ); ``` The following properties are available for the component: | 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 | - | ### Use custom icon with iconfont.cn #### Icon.createFromIconfontCN(options) 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(, 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 }` | {} | The property `scriptUrl` should be set to import the svg sprite symbols. See [iconfont.cn documents](http://iconfont.cn/help/detail?spm=a313x.7781069.1998910419.15&helptype=code) to learn about how to generate `scriptUrl`.