Слияние кода завершено, страница обновится автоматически
<template>
<div v-show="modelValue">
<div v-if="type == 'image'">
<el-image-viewer
v-if="previewLists.length"
:url-list="previewLists"
hide-on-click-modal
@close="handleClose"
/>
</div>
<div v-if="type == 'video'">
<el-dialog v-model="visible" width="740px" title="视频预览" :before-close="handleClose">
<video-player ref="playerRef" :src="url" width="100%" height="450px" />
</el-dialog>
</div>
</div>
</template>
<script lang="ts" setup>
const props = defineProps({
modelValue: {
type: Boolean,
default: false
},
url: {
type: String,
default: ''
},
type: {
type: String,
default: 'image'
}
})
const emit = defineEmits<{
(event: 'update:modelValue', value: boolean): void
}>()
const playerRef = shallowRef()
const visible = computed({
get() {
return props.modelValue
},
set(value) {
emit('update:modelValue', value)
}
})
const handleClose = () => {
emit('update:modelValue', false)
}
const previewLists = ref<any[]>([])
watch(
() => props.modelValue,
(value) => {
if (value) {
nextTick(() => {
previewLists.value = [props.url]
playerRef.value?.play()
})
} else {
nextTick(() => {
previewLists.value = []
playerRef.value?.pause()
})
}
}
)
</script>
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Опубликовать ( 0 )