ant design 预览图片_Image.PreviewGroup 动态删除或替换图片,预览状态下还可以显示删除图片...

代码code如下:

`import React from "react";

import ReactDOM from "react-dom";

import { useState } from "react";

import { Button, Image, version } from "antd";

import "antd/dist/antd.css";

import "./index.css";

const defaultImages = [

{

width: 100,

src: "https://gw.alipayobjects.com/zos/rmsportal/KDpgvguMpGfqaHPjicRK.svg"

}

];

function ImagePreview() {

const [images, setImages] = useState(defaultImages);

const imagesHandle = () => {

setImages([

{

width: 100,

src:

"https://gw.alipayobjects.com/zos/antfincdn/aPkFc8Sj7n/method-draw-image.svg"

}

]);

};

return (

{images.map((image) => (

))}

点击按钮,再点击图片预览出异常

);

}

ReactDOM.render(

antd version: {version},

document.getElementById("root")

);

`

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现可控的`Image.PreviewGroup`组件,你可以使用React的状态管理来控制预览的显隐以及当前预览图片地址。在每次预览时,更新状态并设置当前预览图片地址。以下是一个示例代码: ```jsx import { useState } from 'react'; import { Image } from 'antd'; function MyComponent({ imageUrls }) { const imageUrlArray = imageUrls.split('$'); const [previewVisible, setPreviewVisible] = useState(false); // 控制预览的显隐 const [previewImage, setPreviewImage] = useState(''); // 当前预览图片地址 const handlePreview = (url) => { setPreviewVisible(true); setPreviewImage(url); }; const handleCancel = () => { setPreviewVisible(false); setPreviewImage(''); }; return ( <div> {imageUrlArray.map((url, index) => ( <Image key={index} src={url} onClick={() => handlePreview(url)} // 点击图片时触发预览 /> ))} <Image.PreviewGroup preview={{ visible: previewVisible, onVisibleChange: (visible) => setPreviewVisible(visible), src: previewImage, }} onCancel={handleCancel} > {/* 这里可以为空,只是为了渲染预览 */} <Image key={previewImage} src={previewImage} /> </Image.PreviewGroup> </div> ); } ``` 在上面的示例中,我们使用`useState`来定义两个状态`previewVisible`和`previewImage`,分别控制预览的显隐和当前预览图片地址。`handlePreview`函数在点击图片时被调用,它更新状态并设置当前预览图片地址。`handleCancel`函数在取消预览时被调用,它重置状态以隐藏预览。 在`Image.PreviewGroup`组件中,我们使用了`preview`属性来控制预览的显隐和当前预览图片地址。`onVisibleChange`事件在预览显隐状态改变时被调用,它更新`previewVisible`状态。在`Image.PreviewGroup`组件内部,我们渲染一个空的`Image`组件,只是为了让预览正常工作。 记得在你的组件中引入`useState`和`Image`组件: ```jsx import { useState } from 'react'; import { Image } from 'antd'; ``` 希望对你有所帮助!如有任何疑问,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值