<template>
<div class="basePreview">
<el-dialog
:model-value="dialogVisible"
width="1040px"
:show-close="false"
:before-close="dialogClose"
>
<div class="dialog-content">
<div class="close" @click="dialogClose">
<i class="iconfont icon-ziyuan18"></i>
</div>
<div class="nextPage" @click="nextPageChange">
<i class="iconfont icon-next-icon"></i>
</div>
<div class="lastPage" @click="lastPageChange">
<i class="iconfont icon-next-icon"></i>
</div>
<div class="img-container">
<img :src="mainImage" alt="">
</div>
</div>
<template #footer>
<div class="dialog-footer">
<el-scrollbar style="width:900px;height:90px;margin:auto">
<div class="img-list">
<div class="img-item" :ref="imageItemRef" :class="{active:index == active}" v-for="(item,index) in previewList" :key="index"
@click="choosePreview(item,index)">
<img :src="item" alt="">
</div>
</div>
</el-scrollbar>
</div>
</template>
</el-dialog>
</div>
</template>
<script>
import {
ref,
toRef,
toRefs,
reactive,
watch,
computed,
onBeforeUpdate,
onMounted,
defineComponent,
} from 'vue'
export default defineComponent({
name: 'BasePreview',
props: {
previewList: {
type: Array,
default: [],
},
dialogVisible: {
type: Boolean,
default: false,
},
},
emits: [],
setup(props, context) {
const mainImage = ref()
const active = ref(0)
mainImage.value = props.previewList[0]
let itemRefs = []
const imageItemRef = el => {
if (el && itemRefs.length != props.previewList.length) {
itemRefs.push(el)
}
}
onBeforeUpdate(() => {
itemRefs = []
})
function dialogClose() {
context.emit('close')
}
function choosePreview(item, index) {
mainImage.value = item
active.value = index
itemRefs[active.value].scrollIntoView({behavior:'smooth',block:'center',inline:'center'})
}
function nextPageChange() {
if(active.value <= props.previewList.length - 2) {
active.value = active.value + 1
mainImage.value = props.previewList[active.value]
itemRefs[active.value].scrollIntoView({behavior:'smooth',block:'center',inline:'center'})
}
}
function lastPageChange() {
if(active.value > 0) {
active.value = active.value - 1
mainImage.value = props.previewList[active.value]
itemRefs[active.value].scrollIntoView({behavior:'smooth',block:'center',inline:'center'})
}
}
onMounted(() => {
});
return {
...toRefs(props),
mainImage,
active,
dialogClose,
imageItemRef,
nextPageChange,
lastPageChange,
choosePreview
}
},
})
</script>
<style lang="scss" scoped>
.basePreview {
.dialog-content {
position: relative;
.close {
cursor: pointer;
position: absolute;
right: -80px;
top: -30px;
width: 41px;
line-height: 41px;
text-align: center;
height: 41px;
background-color: #ffffff;
border-radius: 3px;
}
.nextPage{
cursor: pointer;
position: absolute;
right: -90px;
top: 50%;
color: #ffffff;
.icon-next-icon{
font-size: 36px;
}
}
.lastPage{
cursor: pointer;
position: absolute;
left: -90px;
transform:rotate(180deg);
top: 50%;
color: #ffffff;
.icon-next-icon{
font-size: 36px;
}
}
.img-container {
width: 1000px;
height: 519px;
background-color: #c7c7c7;
img {
width: 1000px;
height: 519px;
object-fit: contain;
}
}
}
.dialog-footer {
.img-list {
display: flex;
align-items: center;
width: 900px;
margin: auto;
.img-item {
margin-right: 20px;
width: 82px;
height: 82px;
background-color: #f1f1f1;
border: solid 1px transparent;
cursor: pointer;
&:last-child {
margin-right: 0px;
}
&.active {
border: solid 1px #ffa312;
}
img {
width: 82px;
height: 82px;
object-fit: contain;
}
}
}
}
}
</style>
弹窗预览图片组件
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 1.基础用法 <cube-upload ref="upload1" v-model...
- 基于vue开发 npm i sbd-plugin-group API 上传图片预览 参数说明格式必填默认defIm...
- hello啊,every body ,大家好,之前我们(其实只有我自己啦,为什么用我们呢?可能是为了装作我有一个团...
- 实战需求 SwiftUI iOS 提示组件之 仿Xcode图标图片提示框Alert Toast弹窗(教程含源码) ...