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。

相关推荐
大萝卜呼呼几秒前
Next.js第二课 - 项目结构详解 - 优栈
前端·next.js
skywalkzf几秒前
全志 V853 开发:lunch 不显示项目列表问题排查与解决
前端·chrome
踩着两条虫1 分钟前
VTJ.PRO 在线应用开发平台的项目模板(Web、H5、UniApp)
前端·低代码·ai编程
云原生指北1 分钟前
测试文章标题 - Omnipub 自动发布测试
前端
无责任此方_修行中1 分钟前
"JavaScript"这个名字,到底属于谁?一场价值74亿美元的法律战争
前端·javascript·程序员
CharlesY2 分钟前
网页排版与编码的隐形神器:HTML字符实体从入门到精通
前端
我命由我123456 分钟前
React - useEffect、useRef、Fragment
开发语言·前端·javascript·react.js·前端框架·ecmascript·js
云原生指北6 分钟前
测试文章 - 摘要自定义填充验证
前端
她的男孩8 分钟前
ForgeAdmin 更新:新增第三方登录认证 + 数据字段脱敏两大企业级特性
前端·后端
KevinCyao12 分钟前
Ruby短信营销接口示例代码:Ruby开发环境下营销短信API接口的集成与Demo演示
开发语言·前端·ruby