Image图片

可预览的图片。

何时使用

  • 需要展示图片时使用。

  • 加载大图时显示 loading 或加载失败时容错处理。

代码演示

Image图片 - 图1

基本用法

单击图像可以放大显示。

  1. import { Image } from 'antd';
  2. function ImageDemo() {
  3. return (
  4. <Image
  5. width={200}
  6. src="https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png"
  7. />
  8. );
  9. }
  10. ReactDOM.render(<ImageDemo />, mountNode);

Image图片 - 图2

渐进加载

大图使用 placeholder 渐进加载。

  1. import React from 'react';
  2. import { Image, Button, Space } from 'antd';
  3. function ImageDemo() {
  4. const [random, setRandom] = React.useState();
  5. return (
  6. <Space size={12}>
  7. <Image
  8. width={200}
  9. src={`https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png?${random}`}
  10. placeholder={
  11. <Image
  12. preview={false}
  13. src="https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png?x-oss-process=image/blur,r_50,s_50/quality,q_1/resize,m_mfit,h_200,w_200"
  14. width={200}
  15. />
  16. }
  17. />
  18. <Button
  19. type="primary"
  20. onClick={() => {
  21. setRandom(Date.now());
  22. }}
  23. >
  24. Reload
  25. </Button>
  26. </Space>
  27. );
  28. }
  29. ReactDOM.render(<ImageDemo />, mountNode);

Image图片 - 图3

自定义预览图片

可以设置不同的预览图片。

  1. import React from 'react';
  2. import { Image } from 'antd';
  3. function ImageDemo() {
  4. return (
  5. <Image
  6. width={200}
  7. src="https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png?x-oss-process=image/blur,r_50,s_50/quality,q_1/resize,m_mfit,h_200,w_200"
  8. preview={{
  9. src: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png',
  10. }}
  11. />
  12. );
  13. }
  14. ReactDOM.render(<ImageDemo />, mountNode);

Image图片 - 图4

容错处理

加载失败显示图像占位符。

  1. import { Image } from 'antd';
  2. function ImageDemo() {
  3. return (
  4. <Image
  5. width={200}
  6. height={200}
  7. src="error"
  8. fallback=""
  9. />
  10. );
  11. }
  12. ReactDOM.render(<ImageDemo />, mountNode);

Image图片 - 图5

多张图片预览

点击左右切换按钮可以预览多张图片。

  1. import { Image } from 'antd';
  2. function ImageDemo() {
  3. return (
  4. <Image.PreviewGroup>
  5. <Image
  6. width={200}
  7. src="https://gw.alipayobjects.com/zos/rmsportal/KDpgvguMpGfqaHPjicRK.svg"
  8. />
  9. <Image
  10. width={200}
  11. src="https://gw.alipayobjects.com/zos/antfincdn/aPkFc8Sj7n/method-draw-image.svg"
  12. />
  13. </Image.PreviewGroup>
  14. );
  15. }
  16. ReactDOM.render(<ImageDemo />, mountNode);

API

参数说明类型默认值版本
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 | previewTypetrue4.6.0 previewType:4.7.0
src图片地址string-4.6.0
width图像宽度string | number-4.6.0
onError加载错误回调(event: Event) => void-4.12.0

previewType

  1. {
  2. visible?: boolean;
  3. onVisibleChange?: (visible, prevVisible) => void;
  4. getContainer?: string | HTMLElement | (() => HTMLElement); // V4.8.0
  5. src?: string; // V4.10.0
  6. mask?: ReactNode; // V4.9.0
  7. maskClassName?: string; // V4.11.0
  8. current?: number; // V4.12.0 仅支持 PreviewGroup。
  9. }

其他属性见 <img>