大屏使用el-image组件全屏后图片预览时不显示

文章讲述了在Vue3项目中使用Element-Plus开发大屏应用时,el-image组件的图片预览功能在全屏状态下失效的问题。解决方法包括移除预览遮罩层的body定位和使用独立的el-image-viewer组件,并将其放置在全屏标签内。
摘要由CSDN通过智能技术生成

vue3+element-plus写大屏时遇到的一个问题,el-image组件添加了图片预览功能,但是大屏全屏之后点击预览的时候看不到图片,退出全屏后能正常显示

普通系统页面为防止预览的遮罩层没有覆盖页面所有内容,所以添加这个属性,也就是将遮罩层放到body标签中。但大屏中我们全屏的一般都是指定的标签,全屏之后这个标签就会覆盖body标签,自然就导致图片预览的图片被我们全屏的标签覆盖,解决办法就是去掉这个属性即可

另外大屏中因为很多地方都有图片预览功能,但并不是每个地方都用的el-image组件,也有点击按钮预览图片的,所以我单独使用了el-image-viewer组件,并把它放到要全屏的标签中

<div id="fullscreen">
    <el-image-viewer
        v-if="show.viewPerviewDialog"
        :url-list="pageData.viewPerviewImg"
        hide-on-click-modal
        close-on-press-escape
        @close="show.viewPerviewDialog = false"
        :z-index="9999"
        class="imgviewer"
     />
</div>

'#fullscreen'即是我们要全屏的标签,使用v-if控制显隐,z-index为了防止被覆盖,teleported这个属性一样是插入body标签中,一样不能给。el-image-viewer标签放到全屏的标签外面一样会导致全屏后无法显示预览图片

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值