位置: IT常识 - 正文

vue+element-ui前端使用print-js实现打印,可自定义样式(横纵向,缩放比,字体大小,背景色)(前端 vue)

编辑:rootadmin
vue+element-ui前端使用print-js实现打印,可自定义样式(横纵向,缩放比,字体大小,背景色) vue+element-ui前端使用print-js实现打印下载依赖使用print-js实现打印功能需要打印的内容按钮调用打印函数打印函数设置默认打印横纵向(IE不生效)设置默认打印缩放比调整打印字体大小自定义字体大小生效自定义背景颜色生效参数

推荐整理分享vue+element-ui前端使用print-js实现打印,可自定义样式(横纵向,缩放比,字体大小,背景色)(前端 vue),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vueelementui前端框架,vue前端菜鸟教程,element前端框架,element前端框架,前端element ui,前端element ui,vueelementui前端框架,element 前端,内容如对您有帮助,希望把文章链接给更多的朋友!

print-js官网链接: https://printjs.crabbly.com/

下载依赖npm install print-js --save

在package.json文件中增加print-js依赖。

"dependencies": { "axios": "^0.19.2", "babel-polyfill": "^6.26.0", "element-ui": "^2.15.6", "file-saver": "^2.0.5", "pinyin-match": "^1.2.2", "print-js": "^1.6.0", "vue": "^2.5.2", "vue-router": "^3.0.1", "vuex": "^3.1.2", "xlsx": "^0.17.0", "xlsx-style": "^0.8.13" },

使用print-js

在需要打印的页面对应文件中引入print-js

import printJS from 'print-js'实现打印功能需要打印的内容

需要把表格打印出来,在表格外套一个div,并给一个id值。

<div class="data-card" id="mytable1"> <el-table size="mini" :key="num" id="mytable" :header-cell-style="tableHeaderColor" :span-method="arraySpanMethod" :cell-style="cellStyle" ref="table" :data="tableDataDetail" border stripe style="width: 100%"> <el-table-column align="center" :label="title"> </el-table-column> </el-table> </div>按钮调用打印函数vue+element-ui前端使用print-js实现打印,可自定义样式(横纵向,缩放比,字体大小,背景色)(前端 vue)

定义一个按钮,点击调用打印函数。

<el-button @click="handleDownload()">下载</el-button>打印函数

不同浏览器打印样式不同,使用navigator.userAgent进行了判断。 printJS是引用的print-js对象 printtable为标签元素id type有html,json,pdf等。 header是用于HTML、图像或JSON打印的可选标题。它将被放置在页面的顶部。此属性将接受文本或原始HTML。 style为自定义的样式

handlePrint () { let userAgent = navigator.userAgent; //判断是否Firefox浏览器 if (userAgent.indexOf("Firefox") > -1) { console.log('Firefox') printJS({ printable: 'mytable1', // 标签元素id type: 'html', header: '', style: `@page {size:auto;margin-top:100px; margin-left:15px; margin-right: 15px;} thead th { border-top: 1px solid #000; border-right: 1px solid #000; border-left: 1px solid #000; } tbody td { border: 1px solid #000; } tbody { text-align: center; } table { border-collapse: collapse; }`, }); } //判断是否chorme浏览器 if (userAgent.indexOf("Chrome") > -1){ console.log('Chrome') printJS({ printable: 'mytable1', // 标签元素id type: 'html', header: '', documentTitle: '', style: `@page {size:auto;margin-top:100px; margin-left:5px; margin-right: 15px;} thead th { border-top: 1px solid #000; border-right: 1px solid #000; border-left: 1px solid #000; } tbody td { border: 1px solid #000; } tbody { text-align: center; } table { border-collapse: collapse; }`, }); } //判断是否IE浏览器 if (!!window.ActiveXObject || "ActiveXObject" in window) { console.log('IE') printJS({ printable: 'mytable1', // 标签元素id type: 'html', header: '', style: `@page {size:auto;margin-top:100px; margin-left:15px; margin-right: 15px;} thead th { border-top: 1px solid #000; border-right: 1px solid #000; border-left: 1px solid #000; } tbody td { border: 1px solid #000; } tbody { text-align: center; } table { border-collapse: collapse; }`, }); } },设置默认打印横纵向(IE不生效)

打印横向:@media print{@page {size:landscape}} 打印纵向:@media print{@page {size:portrait}} 加在style里

设置默认打印缩放比

在style中加入body {zoom: 50%;} zoom中写需要的缩放比。

调整打印字体大小

修改print-js文件

修改font_size数值(小于一定数值之后chrome浏览器内打印字体不会变小)

自定义字体大小生效

修改print-js文件 修改font-size生效在206行 将有font-size的匿掉,改成下面一行。

// elementStyle += 'max-width: ' + params.maxWidth + 'px !important; font-size: ' + params.font_size + ' !important;'; elementStyle += 'max-width: ' + params.maxWidth + 'px !important;';自定义背景颜色生效

Chrome & IE中加入这句话: -webkit-print-color-adjust: exact

.back1 { -webkit-print-color-adjust: exact; background-color:rgba(250,240,230,1) !important; }

火狐例子:

.back1 { background-color: unset; box-shadow: inset 0 0 0 1000px rgba(250,240,230,1) }

效果:

参数参数默认值说明printablenull文档源:pdf或图像url、html元素id或json数据对象。type‘pdf’可打印类型。可用的打印选项有:pdf、html、image、json和raw html。headernull用于HTML、图像或JSON打印的可选标题。它将被放置在页面顶部。此属性将接受文本或原始HTML。headerStyle‘font-weight: 300;’要应用于标题文本的可选标题样式。maxWidth800以像素为单位的最大文档宽度。根据需要更改此选项。打印HTML、图像或JSON时使用。cssnull这允许我们传递一个或多个css文件URL,这些URL应该应用于正在打印的html。值可以是具有单个URL的字符串,也可以是具有多个URL的数组。stylenull这允许我们传递一个带有自定义样式的字符串,该字符串应应用于正在打印的html。scanStylestrue设置为false时,库将不会处理应用于正在打印的html的样式。使用css参数时很有用。targetStylenull默认情况下,在打印HTML元素时,库仅处理某些样式。此选项允许您传递要处理的样式数组。例如:[‘pading-top’,‘border-bottom’]targetStylesnull不过,与“targetStyle”相同,它将处理任意范围的样式。例如:[‘border’,‘padding’],将包括“border-bottom”、“bordertop”、“border-left”、“porder-refght”、“padding-top”等。您还可以传递[‘*’]来处理所有样式。ignoreElements[ ]接受打印父html元素时应忽略的html ID数组。propertiesnull打印JSON时使用。这些是对象属性名称。gridHeaderStyle‘font-weight: bold;’打印JSON数据时网格头的可选样式。gridStyle‘border: 1px solid lightgray; margin-bottom: -1px;’打印JSON数据时网格行的可选样式。repeatTableHeadertrue打印JSON数据时使用。设置为false时,数据表标题将仅显示在第一页。showModalnull启用此选项可在检索或处理大型PDF文件时显示用户反馈。modalMessage‘Retrieving Document…’showModal设置为true时向用户显示的消息。onLoadingStartnull加载PDF时要执行的函数onLoadingEndnull加载PDF后要执行的函数documentTitle‘Document’打印html、image或json时,这将显示为文档标题。fallbackPrintablenull打印pdf时,如果浏览器不兼容(检查浏览器兼容性表),库将在新选项卡中打开pdf。这允许您传递要打开的不同pdf文档,而不是传递给“可打印”的原始文档。如果在备用pdf文件中注入javascript,这可能会很有用。onPdfOpennull打印pdf时,如果浏览器不兼容(检查浏览器兼容性表),库将在新选项卡中打开pdf。可以在此处传递回调函数,当发生这种情况时将执行回调函数。在某些需要处理打印流、更新用户界面等的情况下,它可能很有用。onPrintDialogClosenull浏览器打印对话框关闭后执行的回调函数。onErrorerror => throw error发生错误时要执行的回调函数。base64false打印作为base64数据传递的PDF文档时使用。honorMarginPadding(弃用)true这用于保留或删除正在打印的元素的填充和边距。有时这些样式设置在屏幕上很好,但在打印时看起来很糟糕。您可以通过将其设置为false来删除它。honorColor(弃用)false要彩色打印文本,请将此属性设置为true。默认情况下,所有文本将以黑色打印。font(弃用)‘TimesNewRoman’打印HTML或JSON时使用的字体。font_size(弃用)‘12pt’打印HTML或JSON时使用的字体大小。imageStyle(弃用)‘width:100%;’打印图像时使用。接受包含要应用于每个图像的自定义样式的字符串。
本文链接地址:https://www.jiuchutong.com/zhishi/277565.html 转载请保留说明!

上一篇:智能路由器与普通路由器有哪些区别(智能路由器哪个牌子好)

下一篇:公积金贷款额度是多少(公积金贷款额度查询计算器)

  • vivox70pro怎么关闭广告(vivox70Pro怎么关空调)

    vivox70pro怎么关闭广告(vivox70Pro怎么关空调)

  • 新东方云课堂怎么关闭摄像头(新东方云课堂怎么关闭麦克风)

    新东方云课堂怎么关闭摄像头(新东方云课堂怎么关闭麦克风)

  • 微信聊天记录保存在哪个文件夹里(微信聊天记录保存在哪个文件夹)

    微信聊天记录保存在哪个文件夹里(微信聊天记录保存在哪个文件夹)

  • 小米手机软件权限设置在哪里(小米手机软件权限管理在哪里)

    小米手机软件权限设置在哪里(小米手机软件权限管理在哪里)

  • 键的作用(mode键的作用)

    键的作用(mode键的作用)

  • 机器智能的种类包括哪些(机器智能的种类有哪些)

    机器智能的种类包括哪些(机器智能的种类有哪些)

  • 京东自营与京东超市的区别(京东自营与京东自营官方旗舰店的区别)

    京东自营与京东超市的区别(京东自营与京东自营官方旗舰店的区别)

  • iphone双击home键分屏有什么用(iphone双击home键反应变慢)

    iphone双击home键分屏有什么用(iphone双击home键反应变慢)

  • 3600对标的是i几(3600相当于intel)

    3600对标的是i几(3600相当于intel)

  • 4g电话卡可以升级5g吗(4g电话卡可以升到5g吗)

    4g电话卡可以升级5g吗(4g电话卡可以升到5g吗)

  • 笔记本电脑可以用充电宝充电吗?(笔记本电脑可以换显卡吗)

    笔记本电脑可以用充电宝充电吗?(笔记本电脑可以换显卡吗)

  • x什么处理器(荣耀8x什么处理器)

    x什么处理器(荣耀8x什么处理器)

  • qq建立基友关系是什么意思(qq建立基友关系有啥用)

    qq建立基友关系是什么意思(qq建立基友关系有啥用)

  • 什么是web结构标准(什么是web结构标识符)

    什么是web结构标准(什么是web结构标识符)

  • 打开旁白怎么关闭(打开旁白后怎么关闭)

    打开旁白怎么关闭(打开旁白后怎么关闭)

  • a2223和a2217区别(a2221和a2223区别)

    a2223和a2217区别(a2221和a2223区别)

  • word的输入操作有哪两种状态(word2016的输入操作有哪两种状态)

    word的输入操作有哪两种状态(word2016的输入操作有哪两种状态)

  • infinix是什么手机(infinix手机是哪里产的)

    infinix是什么手机(infinix手机是哪里产的)

  • 苹果8p有没有128g的(苹果8p有没有双卡)

    苹果8p有没有128g的(苹果8p有没有双卡)

  • 电池百分比在哪设置苹果11(电池百分比在哪里开oppo)

    电池百分比在哪设置苹果11(电池百分比在哪里开oppo)

  • 一嗨租车怎么申请双免(一嗨租车操作流程)

    一嗨租车怎么申请双免(一嗨租车操作流程)

  • oppo reno上市时间(opporeno6上市时间)

    oppo reno上市时间(opporeno6上市时间)

  • PS基本的照片处理有哪些(ps图片的基本处理)

    PS基本的照片处理有哪些(ps图片的基本处理)

  • 西瓜视频如何免流量(西瓜视频如何免费)

    西瓜视频如何免流量(西瓜视频如何免费)

  • mcpalmcfg.exe是什么进程 有什么用   mcpalmcfg进程查询(mch是什么文件)

    mcpalmcfg.exe是什么进程 有什么用 mcpalmcfg进程查询(mch是什么文件)

  • 发票超过认证期有什么影响
  • 土地增值税税率2023
  • 什么情况下一般纳税人可以简易征收
  • 计提职工非货币福利怎么算
  • 建筑工程怎么确定施工工程进度
  • 煤炭企业在建工程核算探讨
  • 亏损企业对外捐赠的税前扣除
  • 取得消费税出口退税款如何做会计处理?
  • 现金出资可以吗
  • 建筑施工企业印花税计税依据
  • 建筑企业管理部门
  • 长期股权投资的初始计量
  • 退股支付的现金流量表怎么填
  • 进口有退税吗最新政策
  • 补缴去年附加税及滞纳金
  • 发票上可以盖两次章吗
  • 预支差旅费的会计科目
  • 通讯费补贴入什么科目
  • 政府专项拨款账务处理
  • 冲红发票开错了怎么办
  • 融资租赁增值税优惠政策
  • 局域网文件共享不稳定
  • 会计管理制度范本
  • 注册会计师考试科目有哪些
  • 固定资产改扩建过程中,发生的人工费用
  • win11无法安装程序包
  • rtvscn95.exe - rtvscn95是什么进程 有什么用
  • 外汇关闭时间
  • 购进免税农产品进行进项税额抵扣时,其抵扣率为
  • 商贸宝红冲和红字反冲
  • PHP:imagecolorat()的用法_GD库图像处理函数
  • 按实际成本结转6日和7日的材料采购成本
  • 如何修改php.ini
  • 金碟怎么初始化
  • 有问题的原始凭证是什么
  • java 导出excel
  • 灵动cfe
  • 帝国cms怎么调用文章随机段落
  • 小企业会计准则季度报表
  • 公司活动举办属于哪个部门
  • MySQL 5.7 create VIEW or FUNCTION or PROCEDURE
  • 不动产经营租赁发票开具注意
  • 金税四期有很多不实的传言
  • 未达到起征点销售额写多少
  • 如何把有余额的账单删除
  • 小规模纳税人免税政策
  • 工会经费滞纳金怎么算
  • 社保费申报是当月的
  • 购买汽车保险费是否做入固定资产
  • 利息支出可以抵扣进项吗
  • 银行账户维护费收费标准
  • 本年利润净利润的关系
  • mysql 最新稳定版本
  • vista技巧:更改电源默认按钮为关机
  • Windows Server 2008的NPS策略应用
  • 七喜r11c笔记本
  • 网络硬盘在哪
  • win10 win8.1双系统
  • 任务栏图标右键
  • win10纯净系统安装教程
  • window10添加虚拟网卡
  • windows7 excel
  • win8如何调屏幕亮度
  • Unity3D游戏开发毕业论文
  • opengl超级宝典第八版 pdf
  • windows 10一
  • unity jsonutility 数组
  • cls方法可以清除
  • Unity3D游戏开发(第2版)
  • 鼠标瞬间移动
  • 简单的智能家居
  • 对计划单列市税务局不服向谁复议
  • 增值税发票打印时号码不一致怎么办
  • 查账征收个人经营所得税怎么申报
  • 爱信诺开票系统怎么安装
  • 电子税务局房产税原值怎么改
  • 购买税控盘的发票需要交印花税吗?
  • 企业支付的年度报告审计费
  • 企业完税证明怎么打印
  • 普通发票开具时写材料一批需要附什么清单?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设