在el-image组件的预览中添加打印功能(自定义功能)

思路:给图片添加点击事件,通过js获取预览的工具栏,在工具栏中添加自定义按钮及事件

1、html 中 image标签

<el-image

style="width: 139px;

height: 89px"

:src="fileUrl"

:preview-src-list="fileUrl"

@click="handleImageClick(fileUrl)" //添加点击事件

/>

2、再点击事件中,通过js操作dom,添加自定义按钮事件

handleImageClick(fileUrl) {

this.$nextTick(() => {

const viewer = document.querySelector('.el-image-viewer__wrapper') //工具栏的dom

if (viewer) {

// 防止重复添加

if (!document.querySelector('.custom-print-btns')) {

const btn = document.createElement('button') //创建按钮

btn.className = 'custom-print-btns' //按需设计样式

btn.innerHTML = '<i class="el-icon-printer"></i>'

btn.onclick = () => this.printImage(fileUrl) //点击按钮触发事件

const btnGroup = viewer.querySelector('.el-image-viewer__actions__inner')

if (btnGroup) {

btnGroup.appendChild(btn) //在工具中添加按钮

}

}

}

})

},

3、添加后的图

4、打印事件

printImage(fileUrl) {

const printWindow = window.open('', '_blank')

printWindow.document.write(`

<html>

<head>

<title>打印图片</title>

<style>

body { text-align: center; margin: 0; padding: 0; }

img { max-width: 100%; max-height: 100vh; margin: auto; }

</style>

</head>

<body>

<img src="${fileUrl}" />

<script>

window.onload = function() {

setTimeout(function() {

window.print();

window.close();

}, 200);

}

<\/script>

</body>

</html>

`)

printWindow.document.close()

},

5、结果图

相关推荐
陈随易25 分钟前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart1 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒3 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰4 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
山河木马4 小时前
渲染管线-计算得到gl_Position(顶点着色器)之后续GPU流程
javascript·webgl·图形学
竹林8184 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
妙码生花5 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
Awu12275 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
咪库咪库咪6 小时前
Vue3-生命周期
前端
莪_幻尘6 小时前
你的 AI Skill 越多越蠢?Token 上下文爆炸的求生指南
前端·ai编程