import React, { useState, useEffect } from 'react';
import Carousel, { Modal, ModalGateway } from 'react-images';
const Lightbox = (props) => {
const { images = [], open, onClose } = props;
const [modalIsOpen, setModalIsOpen] = useState(open)
useEffect(() => {
setModalIsOpen(open)
}, [images, open])
const toggleModal = () => {
setModalIsOpen(!modalIsOpen)
if (typeof onClose === 'function') {
onClose()
}
}
const styleInit = {
header: (base, state) => ({ //头部样式
position: 'absolute',
top: 90,
right: 90,
zIndex: 9999,
}),
view: (base, state) => ({
textAlign: 'center',
height: state.isFullscreen?'100%':600 //当点击全屏的时候图片样式
})
}
return (
<ModalGateway >
{modalIsOpen ? (
<Modal onClose={toggleModal} >
<Carousel views={images} styles={styleInit}/>
</Modal>
) : null}
</ModalGateway>
);
}
export default Lightbox
一个强大的react图片预览 react-images 组件
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...