vue print-js实现打印功能

vue print-js实现打印功能

  1. 使用npm安装print插件
npm install print-js --save
  1. 在需要的文件里面引入 import Print from ‘print-js’
  2. 在页面调用打印
<template><div><el-button @click="printInfo">打印</el-button><div id="printBox" class="wrap-style" style="" v-show="printFlag"><div class="print-header"><div class="left-content" style="font-weight: 600;"><!-- 左侧内容,可以是文字或图片 -->信息</div><div class="right-content" style="font-weight: 600;"><!-- 右侧内容,可以是文字或图片 --><img src="@/assets/avature.png" alt="" /></div></div><div class="user-box">用户名:xxx 139xxxxxxxx</div><divclass="title"style="width: 100%; font-weight:600;font-size: 1.5em;text-align:center;margin-top: 10px;">用户列表</div><div class="info-box"><div style="font-size: 0.875em;"><span style="font-weight: 600;">打印日期:</span>{{ transDate(printMsg.date) }}</div></div><tablebordercellspacing="0"width="100%"style="margin-top:0;color:#000;border-color:#000;font-size: 0.875em;"><tr><td style="padding: 5px 2px;" width="40" align="center">序号</td><td style="padding: 5px 10px;" width="165" align="center">用户名</td><td style="padding: 5px 10px;" width="100" align="center">手机号</td><td style="padding: 5px 2px;" width="40" align="center">昵称</td><td style="padding: 5px 2px;" width="40" align="center">性别</td><td style="padding: 5px 10px;" align="center">详细信息</td></tr><tr v-for="(item, index) in printTableData" :key="index"><td style="padding: 5px 10px;" align="center">{{ index + 1 }}</td><td style="padding: 5px 10px;">{{ item.name }}</td><td style="padding: 5px 10px;" align="center">{{ item.mobile }}</td><td style="padding: 5px 10px;" align="center">{{ item.nickName }}</td><td style="padding: 5px 10px;" align="center">{{ item.sex }}</td><td style="padding: 5px 10px;">{{ item.detail }}</td></tr><tr><td colspan="2" align="center" style="font-weight: 600;">总数</td><td></td><td style="padding: 5px 10px;font-weight: 600;" align="center">{{ printMsg.total }}</td><td></td><td></td></tr></table></div></div></template>
<script>
import print from "print-js";
export default {data() {return {printFlag: false,printMsg: {},printTableData:[],printTimeout: null,printInterval: null}},methods:{async printInfo() {this.printFlag = true;let result = await getUserList();this.printMsg = result || {};let data = this.printMsg.items || [];this.printTableData = [];data.forEach(el => {this.printTableData.push({id: el.id,name: el.name,mobile: el.mobile,sex: el.sex,nickName: el.nickName,detial: el.detail});});this.printTimeout = setTimeout(() => {this.printInterval = setInterval(() => window.dispatchEvent(new Event("focus")),500);print({printable: "printBox",type: "html",style:".print-header {\n" +"    display: flex;\n" +"     border-bottom: 1px solid #000;\n" +"     align-items: center;\n" +"     height: 45px;\n" +"    justify-content: space-between;\n" +"  }\n" +"\n" +"  .left-content {\n" +"    color: #000;\n" +"    height: 100%;\n" +"    display: flex;\n" +"     align-items: center;\n" +"    font-size: 0.875em;\n" +"  }\n" +"\n" +"  .right-content {\n" +"    width: 74px;\n" +"    height: 30px;\n" +"  }" +"  .right-content img {\n" +"    width: 100%;\n" +"    height: 100%;\n" +"  }" +"  .user-box {\n" +"    font-size: 0.875em;\n" +"    color: #000;\n" +"    font-weight: 600;\n" +"    margin-top: 10px;\n" +"  }" +"  .info-box {\n" +"    font-size: 0.875em;\n" +"    color: #000;\n" +"    display: flex;\n" +"    margin-top: 10px;\n" +"    margin-bottom: 10px;\n" +"    justify-content: space-between;\n" +"  }" +"  .info-box.final {\n" +"    font-size: 0.875em;\n" +"    color: #000;\n" +"    display: flex;\n" +"    margin-top: 10px;\n" +"    justify-content: space-between;\n" +"  }" +"  .main-info-box {\n" +"    font-size: 0.875em;\n" +"    color: #000;\n" +"    border: 1px solid #000;\n" +"    padding: 10px;\n" +"    border-bottom: 0;\n" +"  }" +"  table td {\n" +"    font-size: 0.875em;\n" +"    color: #000;\n" +"    border: 1px solid #000;\n" +"  }" +"table { page-break-inside:auto;border-collapse: collapse; }\n" +"       tr { page-break-inside:avoid; page-break-after:auto; }" +"@page {\n" +"  margin: 0mm 10mm;\n" +"}",scanStyles: false,// targetStyles: ['*'],maxWidth: 754,onPrintDialogClose: () => {clearInterval(this.printInterval);console.log("关闭");this.printFlag = false;}});}, 500);},},beforeDestroy() {this.printTimeout && clearTimeout(this.printTimeout);this.printInterval && clearInterval(this.printInterval);}
}
</script>
<style lang="scss" scoped>
.wrap-style {width: 754px;
}
</style>

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

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

相关文章

【计算机组成与体系结构Ⅱ】指令调度与分支延迟(实验)

实验4&#xff1a;指令调度与分支延迟 一、实验目的 1. 加深对指令调度技术的理解。 2. 加深对分支延迟技术的理解。 3. 熟练采用指令调度技术解决流水线中的数据冲突的方法。 4. 进一步理解指令调度技术对CPU性能的改进。 5. 进一步理解延迟分支技术对CPU性能的改进。 二…

装完32G内存条 电脑飞跃提升!

我是南城余&#xff01;阿里云开发者平台专家博士证书获得者&#xff01; 欢迎关注我的博客&#xff01;一同成长&#xff01; 一名从事运维开发的worker&#xff0c;记录分享学习。 专注于AI&#xff0c;运维开发&#xff0c;windows Linux 系统领域的分享&#xff01; 大家…

MiniTab的拟合回归模型的分析

拟合回归模型概述 使用拟合回归模型和普通最小二乘法可以描述一组预测变量和一个连续响应之间的关系。可以包括交互作用项和多项式项、执行逐步回归和变换偏斜数据。 例如&#xff0c;房地产评估人员想了解城市公寓与多个预测变量&#xff08;包括建筑面积、可用单元数量、建…

【YOLO系列】 YOLOv4之Focal Loss损失函数

论文下载&#xff1a;Focal Loss for Dense Object Detection 一、简介 Focal Loss损失函数何凯明大神在RetinaNet网络中提出来的&#xff0c;主要是为了解决one-stage目标检测中正负样本比例严重失衡的问题。该损失函数降低了大量简单负样本在训练中所占的比重&#xff0c;也可…

MySQL中判断字段的字符数

CHAR_LENGTH函数用于返回字符串的长度&#xff0c;长度单位为字符 不管汉字,数字或是字母都算是一个字符&#xff0c;包括中英文标点符号&#xff0c;空格也算是一个字符 语法结构&#xff1a; CHAR_LENGTH(str) 示例&#xff1a; 表&#xff1a;Tweets ----------------…

安装Anaconda遇到的问题

报错如下&#xff1a; Anaconda3 5.1.0(64-bit) Setup Error:Due to incompatibility with several Pyth on libraries, Destination Folder’cannot contain non-ascii characters(special characters or diacritics). Please choose another location. 原因&#xff1a;安装…

JavaScript三元运算

JavaScript 中的三元运算符是一种简洁的条件语句&#xff0c;其语法结构如下&#xff1a; 条件 ? 表达式1 : 表达式2;这里的“条件”是一个布尔表达式&#xff08;即其结果为 true 或 false&#xff09;。如果条件为 true&#xff0c;则执行并返回“表达式1”的结果&#xff…

【Vue3】3-1 : 章节介绍 - Vue3组件应用及单文件组件

本书目录&#xff1a;点击进入 一、本章学习目标 二、课程安排 一、本章学习目标 Vue3组件相关概念掌握组件之间的通信封装一个可复用的组件单文件组件SFC&#xff1a;即.vue文件 样式 结构 逻辑脚手架的使用和底层实现机制工程化的认知 二、课程安排 组件的概念及组件的基…

AIGC笔记--CVAE模型的搭建

目录 1--CVAE模型 2--代码实例 1--CVAE模型 简单介绍&#xff1a; 与VAE类似&#xff0c;只不过模型的输入需要考虑图片和条件&#xff08;condition&#xff09;的融合&#xff0c;融合结果通过一个 encoder 映射到标准分布&#xff08;均值和方差&#xff09;&#xff0c;从…

基于ssm百货中心供应链管理系统+jsp论文

摘 要 社会发展日新月异&#xff0c;用计算机应用实现数据管理功能已经算是很完善的了&#xff0c;但是随着移动互联网的到来&#xff0c;处理信息不再受制于地理位置的限制&#xff0c;处理信息及时高效&#xff0c;备受人们的喜爱。本次开发一套百货中心供应链管理系统有管理…

transfomer中Decoder和Encoder的base_layer的源码实现

简介 Encoder和Decoder共同组成transfomer,分别对应图中左右浅绿色框内的部分. Encoder&#xff1a; 目的&#xff1a;将输入的特征图转换为一系列自注意力的输出。 工作原理&#xff1a;首先&#xff0c;通过卷积神经网络&#xff08;CNN&#xff09;提取输入图像的特征。然…

构建未来教育:在线培训系统开发的技术探讨

随着远程学习的崛起和数字化教育的普及&#xff0c;在线培训系统的开发成为了现代教育的核心。本文将深入讨论在线培训系统的关键技术要点&#xff0c;涵盖前后端开发、数据库管理、以及安全性和身份验证等关键方面。 前端开发&#xff1a;提供交互性与用户友好体验 在构建在…

02 SpringMVC接收数据之访问路径设置+四种接参方式+@EnableWebMvc

1.1 访问路径设置 RequestMapping注解的作用就是将请求的 URL 地址和处理请求的方式&#xff08;handler方法&#xff09;关联起来&#xff0c;建立映射关系。 SpringMVC 接收到指定的请求&#xff0c;就会来找到在映射关系中对应的方法来处理这个请求。 1.1.1 精准路径匹配…

京东ES支持ZSTD压缩算法上线了:高性能,低成本 | 京东云技术团队

1 前言 在《ElasticSearch降本增效常见的方法》一文中曾提到过zstd压缩算法[1]&#xff0c;一步一个脚印我们终于在京东ES上线支持了zstd&#xff1b;我觉得促使目标完成主要以下几点原因&#xff1a; Elastic官方原因&#xff1a;zstd压缩算法没有在Elastic官方的开发计划中&…

【Leetcode Sheet】Weekly Practice 24

Leetcode Test 447 回旋镖的数量(1.8) 给定平面上 n 对 互不相同 的点 points &#xff0c;其中 points[i] [xi, yi] 。回旋镖 是由点 (i, j, k) 表示的元组 &#xff0c;其中 i 和 j 之间的距离和 i 和 k 之间的欧式距离相等&#xff08;需要考虑元组的顺序&#xff09;。 …

最新智能AI系统ChatGPT网站程序源码+详细图文搭建部署教程,Midjourney绘画,GPT语音对话+ChatFile文档对话总结+DALL-E3文生图

一、前言 SparkAi创作系统是基于ChatGPT进行开发的Ai智能问答系统和Midjourney绘画系统&#xff0c;支持OpenAI-GPT全模型国内AI全模型。本期针对源码系统整体测试下来非常完美&#xff0c;可以说SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如何搭建部署AI创作Ch…

如何增加服务器的高并发

随着互联网的快速发展和普及&#xff0c;越来越多的应用程序需要支持高并发的请求处理。在这种情况下增加服务器的高并发能力成为了一个热门的话题。下面简单的介绍如果提高服务器的高并发能力。 负载均衡 是把请求分发到多个服务器上&#xff0c;来实现请求的平衡和分担。负…

使用JavaScript实现实时在线协作编辑器:从设计到实现

一、引言 随着Web技术的发展&#xff0c;实现在线协作编辑文档已经成为一种常见的需求。通过在线协作&#xff0c;多位用户可以同时编辑同一个文档&#xff0c;并实时看到其他用户的更改。这样的功能需要复杂的技术实现&#xff0c;包括数据同步、冲突解决和实时通信。本篇博客…

(一)环境部署

Python虚拟环境 安装virtualenv pip install virtualenv 创建环境 virtualenv -p D:\python\python.exe(python解释器目录) env-py3.6(虚拟环境目录&#xff0c;名称随意) 在当前目录下生成env-py3.6目录。 激活环境 ...\env-py3.6\Scripts> .\activate 关闭&#xf…

应用架构演变过程、rpc及Dubbo简介

一、应用架构演变历史&#xff1a; 单一应用架构 -> 垂直应用架构 -> 分布式服务架构 -> 微服务架构。 单一应用架构 当网站流量很小时&#xff0c;只需一个应用&#xff0c;将所有功能都部署在一起&#xff0c;以减少部署节点和成本。 此时&#xff0c;用于简化增删…