【图片预览】第二种方式:hooks子组件调用父组件方法

1、ImgViewer/index.tsx

import React from 'react'
import Viewer from 'react-viewer'

interface ImgViewerProps {
  visible: boolean // 是否显示viewer
  images: Array<object> // 图片列表 [{src: '', alt: '',downloadUrl: ''}]
  activeIndex?: number // 下标,默认值为0,只有一张照片时可不传
  handleClose: (value: any) => void // 触发父组件方法
  downloadable?: boolean // 是否支持下载,默认:true
}

const ImgViewer: React.FC<ImgViewerProps> = (props: any) => {
  const { handleClose, visible, images, activeIndex = 0, downloadable = true } = props

  return (
    <Viewer
      visible={visible}
      images={images}
      activeIndex={activeIndex}
      onClose={handleClose}
      onMaskClick={handleClose} // 点击遮罩关闭
      downloadable={downloadable} // 是否显示下载按钮,默认显示,显示时imgs对象中需要有downloadUrl字段
      downloadInNewWindow // 新窗口打开图片
    />
  )
}

export default ImgViewer

2、使用

  import ImgViewer from '@/components/ImgViewer'
  // 传递给 ImgViewer 组件的三个值
  const [visible, setVisible] = useState<boolean>(false)
  const [activeIndex, setActiveIndex] = useState<number>(0)
  const [images, setImages] = useState<any[]>([])
  // 图片预览
  const handleImgPreview = (list: Array<any>, index: number) => {
    const imgList: Array<object> = list.map(({ alt, src }) => ({ alt, src, downloadUrl: src }))
    setVisible(true)
    setActiveIndex(index)
    setImages(imgList)
  }

  DOM:

        <ImgViewer
          handleClose={setVisible.bind(this, false)} // 子组件中通过 handleClose 方法改变父组件中的state
          visible={visible}
          images={images}
          activeIndex={activeIndex}
        />

 

子调父的关键在于,将方法通过props传给子组件;

父调子的关键在于,子组件中通过useImperativeHandle钩子将方法暴露出去,父组件需要引入useRef去调用子组件暴露出来的方法。

对于数据流向,建议将数据放在父组件去处理,子组件只做展示用,不对数据进行操作

 

posted @ 2022-03-09 19:44  吴小明-  阅读(363)  评论(0编辑  收藏  举报