dongyukun
2024-11-08 0d21bc334ff8e175c6bd409f21b3ef8bbb7b2c87
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<script lang="ts" setup>
import { PropType } from 'vue'
import { propTypes } from '@/utils/propTypes'
 
defineOptions({ name: 'ImageViewer' })
 
const props = defineProps({
  urlList: {
    type: Array as PropType<string[]>,
    default: (): string[] => []
  },
  zIndex: propTypes.number.def(200),
  initialIndex: propTypes.number.def(0),
  infinite: propTypes.bool.def(true),
  hideOnClickModal: propTypes.bool.def(false),
  teleported: propTypes.bool.def(false),
  show: propTypes.bool.def(false)
})
 
const getBindValue = computed(() => {
  const propsData: Recordable = { ...props }
  delete propsData.show
  return propsData
})
 
const show = ref(props.show)
 
const close = () => {
  show.value = false
}
</script>
 
<template>
  <ElImageViewer v-if="show" v-bind="getBindValue" @close="close" />
</template>