前端vue3打印,多页打印,不使用插件(工作中让我写一个打印功能)

news2025/1/16 21:02:00

说下总体思路,创建一个组件,里面放多个span字段,然后根据父组件传入的参数,生成子组件,最好我们打印子组件的信息即可。通过我多次ai,探索最后成功了。

子组件代码

@media print  这个我要讲一下,这是控制在打印界面,打印的参数,这是css中的知识,我一开始不晓得,慢慢问ai和网上查资料晓得的。

<template>
  <div id="printable-area">
    <div v-for="(item, index) in printData" :key="index" class="print-item">
      <div class="centered-content" style="font-size: 40px; margin-top: 55px">
        图号:<span style="border-bottom: 1px solid black; display: inline-block; width: 300px;">{{ item.figureNumber }}</span><br>
        名称:<span style="border-bottom: 1px solid black; display: inline-block; width: 300px;">{{ item.name }}</span><br>
        编号:<span style="border-bottom: 1px solid black; display: inline-block; width: 300px; ">{{ item.number }}</span><br>
        研制阶段:<span style="border-bottom: 1px solid black; display: inline-block; width: 300px; ">{{ item.developmentPhase }}</span><br>
        出厂时间:<span style="border-bottom: 1px solid black; display: inline-block; width: 300px; ">{{ item.factoryTime }}</span><br>
      </div>
      <br>
      <div v-if="index < printData.length - 1" class="page-break"></div>
    </div>
  </div>
</template>

<script>
import {defineComponent} from 'vue';

export default defineComponent({
  props: {
    queryParam: Array
  },
  setup(props) {
    const printData = props.queryParam;
    return { printData };
  }
});
</script>

<style>
@media print {
  body {
    background: none !important;
    text-align: center; /* 让 body 内容居中 */
  }
  @page {
    size: 15cm 12cm; /* 设置纸张大小为A4 */
    margin:0; /* 设置页边距 */
  }
  .noprint {
    display: none;
  }
  body {
    background: none !important;
  }
  .page-break {
    page-break-before: always;
  }

}
</style>

父组件

这是element 抽屉,我是为了看参数有没有传入进去,用来测试的。我是通过一个按钮,来实现对子组件传参,把参数传给子组件。

   <div  id="printArea">
      <el-drawer v-model="drawer" title="I am the title" :with-header="false">
      <Print ref="printComponent" :query-param="printData"></Print>
    </el-drawer>
    </div>

打印按钮的按钮事件,根据这个按钮去后端获取参数,我这里 state.printData = xGridProduct.value?.getTableData().tableData,其实就是去后端获取参数去了,因为这是公司的前端框架,基于vxe的,包装的方法,获取了一个表格信息,相当于获取参数。

 <el-button type="success" plain  @click="print">打印</el-button>

这里也很关键,中间我遇到一个问题,那就是经常第一次点击按钮,dom元素没有加载完,就弹出打印框了,所以我加了一个异步事件,还有记得把抽屉关了。

   state.printData = xGridProduct.value?.getTableData().tableData
        state.drawer = true
        // 使用nextTick确保DOM更新后执行
        nextTick(() => {
          const printableElement = document.querySelectorAll('.print-item');
          console.log(printableElement);
          func.getPrint()
          // 确保在抽屉隐藏之前获取到元素
          state.drawer = false;
        });

  func.getPrint() 就是我打印功能实际实现,为什么我这里是func,因为公司把所有方法都放在fun里面,节约了导出,免得一个个导出。我们要用直接点就行了。

中间注释的,是windo打印的方法,但是不晓得为啥子,关于打印的分页功能没有实现,我其实很迷惑。

但是使用这个popupWin就成功了。

讲一下大概思路,因为我前端写了比较少,所以理解这些还是花了一点点时间。

querySelectorAll 因为我们组件有class名字,根据class名字获取 了nodelist,一个元素数组。其实每个元素数组中就是前端的信息。

对了千万不要使用querySelectorOne,我ai生成的时候,发现为什么只打印了一个信息,一开始我以为是我分页没有生效,其实是我只获取了一个node。

 const printableHTML = Array.from(printableElement).map(el => {
          return el.outerHTML;
        }).join('');

这是获取子组件的html元素,因为node节点,里面要通过outerHTML才能获取,反正里面也有很多方法,可以看看,我有点记不到了。

后面的思路就简单,开一个新窗口,然后把你从子节点获取的html元素放到这个窗口中,然后打印这个窗口,最后实现。

getPrint:()=>{
        const printableElement = document.querySelectorAll('.print-item');
        console.log(printableElement);
        // 将 NodeList 转换为字符串,并添加分页符
        // const printableHTML = Array.from(printableElement).map(el => {
        //   return `<div style="page-break-after: always;">${el.outerHTML}</div>`;
        // }).join('');
        const printableHTML = Array.from(printableElement).map(el => {
          return el.outerHTML;
        }).join('');
        // console.log(printableHTML)
        // let bodyHtml = document.body.innerHTML  //获取整个页面内容
        // document.body.innerHTML = printableHTML
        // window.print() //打印
        // document.body.innerHTML = bodyHtml//还原页面内容
        // location.reload()
        const popupWin = window.open('', '_blank', 'width=700,height=1000,scrollbars=no,menubar=no,toolbar=no,location=no,status=no,titlebar=no');
        popupWin.document.write(`
        <html>
          <head>
            <title>Print tab</title>
            <style>
             body {
            background: none !important;
            text-align: center; /* 让 body 内容居中 */
        }
              @media print {
              .noprint {
                display: none;
         }
               @page {
              size: 18cm 15cm; /* 设置纸张大小为A4 */
              margin:0; /* 设置页边距 */
        }
                .noprint {
                    display: none;
                          }
                 .page-break {
                    page-break-before: always;
              }

        }

            </style>
          </head>
          <body>
            ${printableHTML}
          </body>
        </html>
    `);
        popupWin.document.close();
        popupWin.focus();
        popupWin.print();
        popupWin.close();
      },

最后我给大家放下效果图,还有多多点赞,我为了完成这个功能,网上看了博客,都没找到。

虽然最好我是通过ai加上自己人脑慢慢摸索的,哈哈。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2141947.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

泛读笔记:从Word2Vec到BERT

自然语言处理(NLP)模型的发展历史 1.统计方法时期&#xff1a;使用贝叶斯方法、隐马尔可夫模型、概率模型等传统统计方法 2.机器学习时期&#xff1a;支持向量机(SVM)、决策树模型、随机森林、朴素贝叶斯等传统机器学习方法 3.深度学习革命&#xff1a;各种新的深度学习模型&am…

Day28_0.1基础学习MATLAB学习小技巧总结(28)——参数估计函数

利用空闲时间把碎片化的MATLAB知识重新系统的学习一遍&#xff0c;为了在这个过程中加深印象&#xff0c;也为了能够有所足迹&#xff0c;我会把自己的学习总结发在专栏中&#xff0c;以便学习交流。 参考书目&#xff1a; 1、《MATLAB基础教程 (第三版) (薛山)》 2、《MATL…

流程图怎么画?3个好用的在线流程图软件推荐,绘图没烦恼!

目录 什么是流程图&#xff1f; 为什么需要使用流程图&#xff1f; 流程图中各种图形的含义 如何制作流程图&#xff1f; 小结&#xff1a;流程图如何制作&#xff1f; 流程图是表达工作流程或者系统操作过程的有效工具&#xff0c;被广泛应用于各个行业和领域。…

USDT自动化交易【Pinoex】【自动化分析】【ChatGPT量化脚本】

Pinoex 是一个相对较新的加密货币交易平台&#xff0c;虽然具体的自动交易算法细节对外部用户可能并不公开&#xff0c;但我们可以讨论一般情况下加密货币自动交易算法的常见策略和方法。以下是一些可能会被类似平台或个人交易者使用的自动交易算法和策略。 1. 市场制造商&…

数据结构——原来二叉树可以这么学?(4.链式二叉树)

前言&#xff1a; 在前两篇小编讲述了二叉树的顺序结构存储方式&#xff0c;从而讲到了一个特殊的二叉树——堆&#xff0c;通过对于堆的实现来帮助我们对于顺序结构存储方式的实现&#xff0c;下面小编将要讲述二叉树的另一种存储方式——链式结构&#xff0c;链式二叉树来喽&…

专业学习|GERT网络概览(学习资源、原理介绍、变体介绍)

一、GERT 网络概览 GERT(Graphical Evaluation Review Technique&#xff0c;图示评审技术)是一种结合流线图理论(Flow Graphical Theory)、矩母函数(Moment Generating Function)、计划评审技术(Program Evaluation Review Technique)解决随机网络问题的方法&#xff0c;描述各…

2024年CAD图纸加密软件|加密图纸软件推荐:10款高效CAD加密软件

在当今数字化时代&#xff0c;CAD图纸已成为工程设计、建筑规划、机械制造等领域不可或缺的重要文件。然而&#xff0c;随着数据泄露和信息安全问题的日益严重&#xff0c;保护CAD图纸的安全性变得尤为重要。为了确保设计数据的安全&#xff0c;使用高效的CAD图纸加密软件成为了…

CMAT:提升小型语言模型的多智能体协作调优框架

人工智能咨询培训老师叶梓 转载标明出处 大模型&#xff08;LLMs&#xff09;已经成为自然语言处理&#xff08;NLP&#xff09;的基石。然而&#xff0c;这些模型的有效运行仍然在很大程度上依赖于人为输入来准确引导对话流程。为了解决这一问题&#xff0c;来自华东交通大学…

comfyui中报错 Cmd(‘git‘) failed due to: exit code(128) 如何解决

&#x1f388;背景 comfyui今天在安装插件的过程中&#xff0c;发现有个插件第一次安装失败后&#xff0c;再次安装就开始报错了&#xff0c;提示&#xff1a; ComfyUI-Inpaint-CropAndStitch install failed: Bad Request 截图如下&#xff1a; 看下后台的报错&#xff1a; …

Html css水平居中+垂直居中+水平垂直居中的方法总结

1. Html css水平居中垂直居中水平垂直居中的方法总结 1.1. Html 元素 1.1.1.元素宽高特点 &#xff08;1&#xff09;块级元素&#xff08;如div&#xff09;&#xff1a;独占一行&#xff0c;不和其他元素在一起&#xff0c;可以设置宽和高&#xff1b;当没设置宽和高时&am…

宝塔面板FTP连接时“服务器发回了不可路由的地址。使用服务器地址代替。”

参考 https://blog.csdn.net/neizhiwang/article/details/106628899 错误描述 我得服务器是腾讯&#xff0c;然后使用宝塔建了个HTML网站&#xff0c;寻思用ftp上传&#xff0c;结果报错&#xff1a; 状态: 连接建立&#xff0c;等待欢迎消息... 状态: 初始化 TLS 中... 状…

go多线程

1、简单使用&#xff08;这个执行完成&#xff0c;如果进程执行比较久&#xff0c;这里不会等待它们结束&#xff09; package mainimport "time"func main() {go func() {println("Hello, World!")}()time.Sleep(1 * time.Second) }2、wg.Add(数量)使用&…

nginx服务介绍

nginx 安装使用配置静态web服务器 Nginx是一个高性能的Web服务器和反向代理服务器&#xff0c;它最初是为了处理大量并发连接而设计的。Nginx还可以用作负载均衡器、邮件代理服务器和HTTP缓存。它以其轻量级、稳定性和高吞吐量而闻名&#xff0c;广泛用于大型网站和应用中 Ngin…

2024ICPC网络赛1: C. Permutation Counting 4

题意&#xff1a; 给定 n n n个区间 [ L i , R i ] [L_i,R_i] [Li​,Ri​]设集合 A { { p i } ∣ p i 为排列&#xff0c; L i < p i < R i } A\{ \{ p_i\} | p_i为排列&#xff0c;Li<p_i<R_i\} A{{pi​}∣pi​为排列&#xff0c;Li<pi​<Ri​}&#xff…

图解Redis 01 | 初识Redis

什么是 Redis&#xff1f; Redis 是一种基于内存的数据库&#xff0c;所有的数据读写操作都在内存中完成&#xff0c;因此读写速度非常快。它被广泛应用于缓存、消息队列、分布式锁等场景。 Redis 提供了多种数据类型来支持不同的业务需求&#xff0c;如 String、Hash、List、…

Vscode 中新手小白使用 Open With Live Server 的坑

背景 最近在家学习尝试前端项目打包的一些事项&#xff0c;既然是打包&#xff0c;那么肯定就会涉及到对打包后文件的访问&#xff0c;以直观的查看打包后的效果 那么肯定就会使用到 Vscode 中 Open With LIve Server 这个功能了&#xff0c;首先这个是一个叫 Live Server 的…

18、Python如何读写csv文件

先简单介绍一下 csv 格式的文件是什么意思。先看一下百度百科怎么说的。 逗号分隔值&#xff08;Comma-Separated Values&#xff0c;CSV&#xff0c;有时也称为字符分隔值&#xff0c;因为分隔字符也可以不是逗号&#xff09;&#xff0c;其文件以纯文本形式存储表格数据&…

企业绿色信贷水平研究:全国与分省份数据分析(2005-2021年)

企业绿色信贷水平指的是企业在信贷活动中&#xff0c;根据环保和产业政策&#xff0c;对环保企业进行扶持&#xff0c;对污染企业进行资金遏制的能力。 2005-2021年 上市企业绿色信贷水平全国、分省份数据&#xff08;原始数据和计算方法&#xff09;https://download.csdn.ne…

鸿蒙读书笔记2:《鸿蒙操作系统设计原理与架构》

2. OS基础平台部件化 &#xff08;1&#xff09;内核层 内核层包括内核部件和HDF驱动框架部件。当前已提供LiteOS-M、 LiteOS-A、Linux和UniProton这4种内核部件&#xff0c;未来还可增加更多类 型的内核部件。LiteOS、Linux内核部件可以按需部署在不同设备之 上&#xff0c;内…

腾讯百度阿里华为常见算法面试题TOP100(3):链表、栈、特殊技巧

之前总结过字节跳动TOP50算法面试题&#xff1a; 字节跳动常见算法面试题top50整理_沉迷单车的追风少年-CSDN博客_字节算法面试题 链表 160.相交链表 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode(int x) …