mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-19 06:43:16 +08:00
380cae80bc
Co-authored-by: afc163 <afc163@gmail.com>
7.3 KiB
7.3 KiB
category | group | title | subtitle | description | cols | cover | coverDark |
---|---|---|---|---|---|---|---|
Components | 数据展示 | Image | 图片 | 可预览的图片。 | 2 | https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*FbOCS6aFMeUAAAAAAAAAAAAADrJ8AQ/original | https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*LVQ3R5JjjJEAAAAAAAAAAAAADrJ8AQ/original |
何时使用
- 需要展示图片时使用。
- 加载显示大图或加载失败时容错处理。
代码演示
基本用法
容错处理
渐进加载
多张图片预览
相册模式
自定义预览图片
受控的预览
自定义工具栏
自定义预览内容
自定义预览文本
嵌套
多图预览时顶部进度自定义
自定义组件 Token
在渲染函数中获取图片信息
API
通用属性参考:通用属性
Image
参数 | 说明 | 类型 | 默认值 | 版本 |
---|---|---|---|---|
alt | 图像描述 | string | - | 4.6.0 |
fallback | 加载失败容错地址 | string | - | 4.6.0 |
height | 图像高度 | string | number | - | 4.6.0 |
placeholder | 加载占位,为 true 时使用默认占位 |
ReactNode | - | 4.6.0 |
preview | 预览参数,为 false 时禁用 |
boolean | PreviewType | true | 4.6.0 PreviewType:4.7.0 |
src | 图片地址 | string | - | 4.6.0 |
width | 图像宽度 | string | number | - | 4.6.0 |
onError | 加载错误回调 | (event: Event) => void | - | 4.12.0 |
其他属性见 <img>
PreviewType
参数 | 说明 | 类型 | 默认值 | 版本 |
---|---|---|---|---|
visible | 是否显示 | boolean | - | - |
src | 自定义预览 src | string | - | 4.10.0 |
getContainer | 指定预览挂载的节点,但依旧为全屏展示,false 为挂载在当前位置 | string | HTMLElement | (() => HTMLElement) | false | - | 4.8.0 |
movable | 是否可移动 | boolean | true | 5.8.0 |
mask | 缩略图遮罩 | ReactNode | - | 4.9.0 |
maskClassName | 缩略图遮罩类名 | string | - | 4.11.0 |
rootClassName | 预览图的根 DOM 类名 | string | - | 5.4.0 |
scaleStep | 1 + scaleStep 为缩放放大的每步倍数 |
number | 0.5 | - |
minScale | 最小缩放倍数 | number | 1 | 5.7.0 |
maxScale | 最大放大倍数 | number | 50 | 5.7.0 |
closeIcon | 自定义关闭 Icon | React.ReactNode | - | 5.7.0 |
forceRender | 强制渲染预览图 | boolean | - | - |
toolbarRender | 自定义工具栏 | (originalNode: React.ReactElement, info: Omit<ToolbarRenderInfoType, 'current' | 'total'>) => React.ReactNode | - | 5.7.0, info.image : 5.18.0 |
imageRender | 自定义预览内容 | (originalNode: React.ReactElement, info: { transform: TransformType, image: ImgInfo }) => React.ReactNode | - | 5.7.0, image: 5.18.0 |
destroyOnClose | 关闭预览时销毁子元素 | boolean | false | |
onTransform | 预览图 transform 变化的回调 | { transform: TransformType, action: TransformAction } | - | 5.7.0 |
onVisibleChange | 当 visible 发生改变时的回调 |
(visible: boolean, prevVisible: boolean) => void | - | - |
PreviewGroup
参数 | 说明 | 类型 | 默认值 | 版本 |
---|---|---|---|---|
preview | 预览参数,为 false 时禁用 |
boolean | PreviewGroupType | true | 4.6.0 PreviewGroupType:4.7.0 |
items | 预览数组 | string[] | { src: string, crossOrigin: string, ... }[] | - | 5.7.0 |
fallback | 加载失败容错地址 | string | - | 5.7.0 |
PreviewGroupType
参数 | 说明 | 类型 | 默认值 | 版本 |
---|---|---|---|---|
visible | 是否显示 | boolean | - | - |
getContainer | 指定预览挂载的节点,但依旧为全屏展示,false 为挂载在当前位置 | string | HTMLElement | (() => HTMLElement) | false | - | 4.8.0 |
movable | 是否可移动 | boolean | true | 5.8.0 |
current | 当前预览图的 index | number | - | 4.12.0 |
mask | 缩略图遮罩 | ReactNode | - | 4.9.0 |
maskClassName | 缩略图遮罩类名 | string | - | 4.11.0 |
rootClassName | 预览图的根 DOM 类名 | string | - | 5.4.0 |
scaleStep | 1 + scaleStep 为缩放放大的每步倍数 |
number | 0.5 | - |
minScale | 最小缩放倍数 | number | 1 | 5.7.0 |
maxScale | 最大放大倍数 | number | 50 | 5.7.0 |
closeIcon | 自定义关闭 Icon | React.ReactNode | - | 5.7.0 |
forceRender | 强制渲染预览图 | boolean | - | - |
countRender | 自定义预览计数内容 | (current: number, total: number) => React.ReactNode | - | 4.20.0 |
toolbarRender | 自定义工具栏 | (originalNode: React.ReactElement, info: ToolbarRenderInfoType) => React.ReactNode | - | 5.7.0, info.image : 5.18.0 |
imageRender | 自定义预览内容 | (originalNode: React.ReactElement, info: { transform: TransformType, image: ImgInfo, current: number }) => React.ReactNode | - | 5.7.0, image: 5.18.0 |
onTransform | 预览图 transform 变化的回调 | { transform: TransformType, action: TransformAction } | - | 5.7.0 |
onChange | 切换预览图的回调 | (current: number, prevCurrent: number) => void | - | 5.3.0 |
onVisibleChange | 当 visible 发生改变时的回调 |
(visible: boolean, prevVisible: boolean, current: number) => void | - | current 参数 5.3.0 |
Interface
TransformType
{
x: number;
y: number;
rotate: number;
scale: number;
flipX: boolean;
flipY: boolean;
}
TransformAction
type TransformAction =
| 'flipY'
| 'flipX'
| 'rotateLeft'
| 'rotateRight'
| 'zoomIn'
| 'zoomOut'
| 'close'
| 'prev'
| 'next'
| 'wheel'
| 'doubleClick'
| 'move'
| 'dragRebound'
| 'reset';
ToolbarRenderInfoType
{
icons: {
flipYIcon: React.ReactNode;
flipXIcon: React.ReactNode;
rotateLeftIcon: React.ReactNode;
rotateRightIcon: React.ReactNode;
zoomOutIcon: React.ReactNode;
zoomInIcon: React.ReactNode;
};
actions: {
onActive?: (index: number) => void; // 5.21.0 之后支持
onFlipY: () => void;
onFlipX: () => void;
onRotateLeft: () => void;
onRotateRight: () => void;
onZoomOut: () => void;
onZoomIn: () => void;
onReset: () => void; // 5.17.3 之后支持
onClose: () => void;
};
transform: TransformType,
current: number;
total: number;
image: ImgInfo
}
ImgInfo
{
url: string;
alt: string;
width: string | number;
height: string | number;
}