ant-design/components/icon/index.zh-CN.md
2018-07-20 16:55:45 +08:00

97 lines
3.5 KiB
Markdown

---
category: Components
subtitle: 图标
type: General
title: Icon
toc: false
---
语义化的矢量图形。
## 图标的命名规范
我们为每个图标赋予了语义化的命名,命名规则如下:
- 实心和描线图标保持同名,用 `-o` 来区分,比如 `question-circle`(实心) 和 `question-circle-o`(描线);
- 命名顺序:`[图标名]-[形状?]-[描线?]-[方向?]`。
> `?` 为可选。
完整的图标设计规范请访问 [图标规范](/docs/spec/icon)。
## 图标列表
请参阅 [Ant Design 图标库](#)。
## API
### Icon
| 参数 | 说明 | 类型 | 默认值 |
| --- | --- | --- | --- |
| spin | 是否有旋转动画 | boolean | false |
| style | 设置图标的样式,例如 fontSize 和 color | object | - |
| type | 图标类型 | string | - |
所有的图标都会以 `<svg>` 标签渲染,可以使用 `style``className` 设置图标的大小和单色图标的颜色。例如:
```jsx
<Icon type="message" style={{ fontSize: 16, color: '#08c' }} />
```
### Icon.CustomIcon
| 参数 | 说明 | 类型 | 默认值 |
| --- | --- | --- | --- |
| spin | 是否有旋转动画 | boolean | false |
| style | 设置图标的样式,例如 fontSize 和 color | object | - |
| viewBox | 设置图标[视图容器盒](https://developer.mozilla.org/zh-CN/docs/Web/SVG/Attribute/viewBox)的大小 | string | '0 0 1024 1024' |
| component | 控制如何渲染图标,通常是一个渲染为 `<svg>` 标签的 `React` 组件 | `React.ComponentType<CustomIconComponentProps>` | - |
`component` 属性类似 `react-router v4``<Route />` 组件的 `component` 属性,描述了图标的如何渲染,对其渲染过程拥有很强的编程控制力。
#### CustomIconComponentProps
`Icon.CustomIcon` 中的 `component` 组件属性如下:
| 参数 | 说明 | 类型 | 默认值 |
| --- | --- | --- | --- |
| width | `svg` 元素宽度 | `Readonly<string | number>` | '1em' |
| height | `svg` 元素高度 | `Readonly<string | number>` | '1em' |
| fill | `svg` 元素填充的颜色 | `Readonly<string>` | 'currentColor' |
| viewBox | 图标[视图容器盒](https://developer.mozilla.org/zh-CN/docs/Web/SVG/Attribute/viewBox)的大小,继承自自定义组件的 `viewBox` 属性 | `Readonly<string>` | '0 0 1024 1024' |
### Icon.create(options)
使用方式如下:
```js
const MyIcon = Icon.create({});
// after importing SVG symbols
ReactDOM.render(<MyIcon type="example" />, mountedNode);
```
其本质上是创建了一个使用 `<use>` 标签来渲染图标的组件。
`options` 的配置项如下:
| 参数 | 说明 | 类型 | 默认值 |
| --- | --- | --- | --- |
| prefix | 设置图标的前缀,通常以短横线结尾,如 `icon-`、`foo-` | string | '' |
| extraCommonProps | 给所有的 `svg` 图标设置额外的属性 | `{ [key: string]: any }` | {} |
| namespace | 图标集合的名字空间,在 `scriptUrl` 也设置的情况下有效,用于区分已导入的图标符号集合 | string | - |
| scriptUrl | [iconfont.cn](http://iconfont.cn/) 项目在线生成的 `js` 地址,在 `namespace` 也设置的情况下有效 | string | - |
`namespace``scriptUrl` 都设置有效的情况下,组件在渲染前会自动引入 [iconfont.cn](http://iconfont.cn/) 项目中的图标符号集,无需手动引入。
见 [iconfont.cn 使用帮助](http://iconfont.cn/help/detail?spm=a313x.7781069.1998910419.15&helptype=code) 查看如何生成 `js` 地址。
<style>
[id^="components-icon-demo-"] .code-box-demo .anticon {
font-size: 18px;
margin-right: 6px;
}
</style>