vue2升级vue3:图片点击预览出现样式错乱

表格内的图片点击预览出现样式错乱

表格里的图片预览后,预览层只显示在表格区域里,没有覆盖整个页面,而是被页面容器"裁剪"了,看起来像是只在表格区域中间显示一块

这在 Element Plus 的 el-image 预览里是一个比较常见的问题,原因通常是:

1️⃣ 父容器有 transform / overflow 导致层级被限制

很多后台布局(如 el-table 外层、dialogdrawerlayout)会有:

css 复制代码
overflow: hidden;
transform: translate3d(...);

这样会导致 fixed / teleport 的层被限制在父容器内

所以预览层就不会覆盖整个页面,而是被裁剪。

2️⃣ preview-teleported 没有开启(Element Plus 关键属性)

Element Plus 中,图片预览需要开启 teleport 到 body

你现在的代码:

ini 复制代码
<el-image
  class="table-image-preview"
  style="width: 90px; height: 50px"
  :src="scope.row.appendixFiles[0].fullUrlShow"
  :preview-src-list="scope.row.imgList"
  :append-to-body="true"
  fit="cover"
>

append-to-body 其实 不是 el-image 的属性

正确写法应该是:

ini 复制代码
<el-image
  class="table-image-preview"
  style="width: 90px; height: 50px"
  :src="scope.row.appendixFiles[0].fullUrlShow"
  :preview-src-list="scope.row.imgList"
  preview-teleported
  fit="cover"
/>

✅ 改成这样

ini 复制代码
<el-image
  class="table-image-preview"
  style="width: 90px; height: 50px"
  :src="scope.row.appendixFiles[0].fullUrlShow"
  :preview-src-list="scope.row.imgList"
  :preview-teleported="true"
  fit="cover"
/>

3️⃣ 如果还不行,再检查这个 CSS

某些布局会有:

css 复制代码
.el-table__body-wrapper {
  overflow: hidden;
}

可以测试:

css 复制代码
.el-table {
  overflow: visible;
}

不过 一般 preview-teleported 就能解决


📌 最推荐写法(完整)

ini 复制代码
<el-table-column label="图片" align="center" min-width="90px">
  <template #default="scope">
    <div v-if="scope.row.appendixFiles?.length">
      <el-image
        style="width:90px;height:50px"
        :src="scope.row.appendixFiles[0].fullUrlShow"
        :preview-src-list="scope.row.imgList"
        :preview-teleported="true"
        fit="cover"
      />
    </div>
  </template>
</el-table-column>

💡 额外建议(企业项目常用)

如果你的 imgList 其实只有一张,可以这样写更安全:

ruby 复制代码
:preview-src-list="[scope.row.appendixFiles[0].fullUrlShow]"

避免 imgList undefined。

相关推荐
IT_陈寒1 小时前
Python搞不定字符串编码?这破玩意坑我两小时!
前端·人工智能·后端
DigitalOcean2 小时前
Laravel 开发者已在 DigitalOcean 上开通超过 10 万台服务器
前端·laravel
星始流年2 小时前
从 Tool 到 Skill——基于 LangChain 的服务端Skill实现
前端·langchain·agent
李惟3 小时前
开源本地通信库,纯客户端 RPC,像聊天一样通信
前端
YAwu113 小时前
深入解析 React 炫彩鼠标跟随标题组件:从坐标定位到动画性能
前端·react.js
GuWenyue3 小时前
排序效率低?5分钟吃透快速排序,性能飙升至O(nlogn)
前端·javascript·面试
OpenTiny社区3 小时前
🎨 看完 GenUI SDK 源码我悟了!
前端·vue.js·github
叁两3 小时前
前端转型AI Agent该如何学习?(前置篇)
前端·人工智能·node.js
何时梦醒3 小时前
深入理解递归与快速排序 —— 从基础入门到手写实现
前端·javascript
爱勇宝3 小时前
淡泊名利之前,先承认我们都很焦虑
前端·后端·程序员