You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
126 lines
4.3 KiB
126 lines
4.3 KiB
## 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<CustomIconComponentProps\> | - |
|
|
| twoToneColor | Only support the two-tone icon. Specific the primary color. | string (hex color) | - |
|
|
|
|
### SVG icons
|
|
|
|
We introduced SVG icons in `1.2.0` version replacing font icons which brings benefits below:
|
|
|
|
- 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.
|
|
- 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.
|
|
|
|
More discussion of SVG icon reference to [#10353](https://github.com/ant-design/ant-design/issues/10353).
|
|
|
|
> ⚠️ About the extra bundle size brought by all SVG icons we imported in 1.2.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.
|
|
|
|
The properties `theme`, `component` and `twoToneColor` are added in `1.2.0`. The best practice is to pass the property `theme` to every `<Icon />` components.
|
|
|
|
```html
|
|
<a-icon type="star" theme="filled" />
|
|
```
|
|
|
|
All the icons will render to `<svg>`. You can still set `style` and `class` for size and color of icons.
|
|
|
|
```html
|
|
<a-icon type="message" :style="{ fontSize: '16px', color: '#08c' }" />
|
|
```
|
|
|
|
### Set TwoTone Color
|
|
|
|
When using the two-tone icons, you can use the static methods `Icon.getTwoToneColor()` and `Icon.setTwoToneColor(colorString)` to spicify the primary color.
|
|
|
|
```jsx
|
|
import { Icon } from 'ant-design-vue'
|
|
|
|
Icon.setTwoToneColor('#eb2f96');
|
|
Icon.getTwoToneColor(); // #eb2f96
|
|
```
|
|
|
|
### 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
|
|
});
|
|
|
|
new Vue({
|
|
el: '#app',
|
|
template: '<my-icon type="icon-example" />',
|
|
components: {
|
|
'my-icon': MyIcon,
|
|
}
|
|
})
|
|
```
|
|
|
|
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`.
|
|
|
|
### Custom SVG Icon
|
|
|
|
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.
|
|
|
|
new Vue({
|
|
el: '#app',
|
|
template: '<a-icon :component="MessageSvg" />',
|
|
components: {
|
|
'my-icon': MyIcon,
|
|
}
|
|
})
|
|
```
|
|
|
|
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' |
|
|
| class | The computed class name of the `svg` element | string | - |
|
|
| style | The computed style of the `svg` element | CSSProperties | - |
|