位置: 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 转载请保留说明!

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

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

  • mate30pro如何设置超级快充(mate30pro如何设置无线充电)

    mate30pro如何设置超级快充(mate30pro如何设置无线充电)

  • 苹果11屏幕摔碎了怎么办(苹果11屏幕摔碎了原图)

    苹果11屏幕摔碎了怎么办(苹果11屏幕摔碎了原图)

  • 抖音收藏别人视频别人能不能看得到吗(抖音收藏别人视频发的宽度没那么大呢)

    抖音收藏别人视频别人能不能看得到吗(抖音收藏别人视频发的宽度没那么大呢)

  • 微信官方收款码能换吗(微信官方收款码和个人收款码的区别)

    微信官方收款码能换吗(微信官方收款码和个人收款码的区别)

  • 微信etc激活不了(微信etc激活后 需要充值吗)

    微信etc激活不了(微信etc激活后 需要充值吗)

  • 手机显示5g网络速度还是4g的(4g手机显示5g网络)

    手机显示5g网络速度还是4g的(4g手机显示5g网络)

  • 抖音怎么看关注的人的直播(抖音怎么看关注的人列表)

    抖音怎么看关注的人的直播(抖音怎么看关注的人列表)

  • mini4可以单独换外屏吗(mini4换mini6)

    mini4可以单独换外屏吗(mini4换mini6)

  • qq登录资料辅助验证失败(qq登录资料辅助验证)

    qq登录资料辅助验证失败(qq登录资料辅助验证)

  • 苹果11看视频画面抖动(苹果11看视频画面模糊)

    苹果11看视频画面抖动(苹果11看视频画面模糊)

  • 为什么word文档下面空一块(为什么word文档上一页还有空白却打不了字)

    为什么word文档下面空一块(为什么word文档上一页还有空白却打不了字)

  • 苹果电量90用换吗(苹果电量90用换电池吗)

    苹果电量90用换吗(苹果电量90用换电池吗)

  • 腾讯课堂直播有回放吗(腾讯课堂直播有回音怎么办)

    腾讯课堂直播有回放吗(腾讯课堂直播有回音怎么办)

  • premiere是什么软件(premiere是什么软件融什么和什么处理与一体)

    premiere是什么软件(premiere是什么软件融什么和什么处理与一体)

  • 抖音怎么拍59秒(抖音里怎么才能拍出超过60秒的视频)

    抖音怎么拍59秒(抖音里怎么才能拍出超过60秒的视频)

  • 苹果11面容可以设置几个(苹果11面容可以更换吗)

    苹果11面容可以设置几个(苹果11面容可以更换吗)

  • 淘宝违规行为分为那两种(淘宝违规行为分为一般和严重两类)

    淘宝违规行为分为那两种(淘宝违规行为分为一般和严重两类)

  • vivoz5x手机有呼吸灯吗(vivo手机呼叫功能)

    vivoz5x手机有呼吸灯吗(vivo手机呼叫功能)

  • 移动光猫注册灯闪烁(移动光猫注册灯闪烁什么原因)

    移动光猫注册灯闪烁(移动光猫注册灯闪烁什么原因)

  • 爱奇艺会员怎么扫码登录(爱奇艺会员怎么让别人退出登录)

    爱奇艺会员怎么扫码登录(爱奇艺会员怎么让别人退出登录)

  • 怎么把ppt调成兼容模式(ppt怎么设置为兼容)

    怎么把ppt调成兼容模式(ppt怎么设置为兼容)

  • 省电模式废电池吗(省电模式损坏电池吗)

    省电模式废电池吗(省电模式损坏电池吗)

  • 如何去除Word2003页眉中的下划线(如何去除word2003文档中的底色)

    如何去除Word2003页眉中的下划线(如何去除word2003文档中的底色)

  • vue3 antd项目实战——Form表单的重置【使用resetFields()重置form表单数据、清空输入框】(ant design vue vue3)

    vue3 antd项目实战——Form表单的重置【使用resetFields()重置form表单数据、清空输入框】(ant design vue vue3)

  • 启动vue-element-admin 安装npm install报错npm ERR! code 128npm ERR! An unknown git error occurre(启动电容坏了的表现)

    启动vue-element-admin 安装npm install报错npm ERR! code 128npm ERR! An unknown git error occurre(启动电容坏了的表现)

  • 不予认定一般纳税人
  • 核定征收的计算方法有哪些
  • 以前年度多计管账怎么做
  • 购车保险返现如何做会计凭证
  • 购销合同签定有法律效力吗
  • 汇算清缴的利润表本期数与本年数
  • 去新成立的公司
  • 固定资产递延所得税负债
  • 然后销售产品
  • 为什么企业要预缴增值税
  • 增值税普通发票和普通发票的区别怎么交税
  • 工资表中有哪些项目
  • 增值税如何进行抵扣
  • 母公司向全资子公司增资
  • 其他应付款可以用其他应收款代替吗
  • 两处拿工资的缴税问题
  • 增值税纳税申报表在哪里打印
  • 农机公司也要缴残保金吗
  • 如何解决浏览器禁止访问
  • 企业如何选择会计师事务所
  • 没进项能开销项吗
  • 苹果icloud储存空间怎么查看内容
  • 出租商品计入什么科目
  • php stl
  • 合同的第三方指什么
  • 前端打印语句
  • php in
  • 取得土地使用权的方式
  • 无形资产属于哪一类
  • 以前年度损益调整在利润表中怎么填
  • 分公司改为子公司的所得税业务处理?
  • WP Smart Preloader 为你的WordPress添加预加载动画
  • 资产负债表中应收账款的计算公式
  • 什么是企业的应付账款
  • 厂房建设包括哪些
  • 润滑脂开票属于哪一类
  • sql server触发器在哪里?
  • 增值税期末留抵退税
  • 代扣代缴增值税要交附加税吗
  • 长期待摊费用的最新账务处理
  • 航天金税服务费280元每年都交吗
  • 发票开错作废如何处理?
  • 长期预付账款涉税
  • 其他应付款贷方正数表示什么意思
  • 劳务报酬税目
  • 稳岗返还计入营业外收入
  • 付境外股东股利要交什么税
  • 股东借款转实收资本
  • 公司提前扣员工保险合法吗
  • 间接持股比例如何分析
  • 经营活动产生的现金流量净额越大越好吗
  • 加盟创业成功案例分析
  • 期末留抵税额会计分录
  • 应付职工薪酬账户贷方登记的是
  • 判断成本法核算方法
  • 销售净利润怎么算
  • sql server常用
  • XP系统升级WIN7系统
  • crowd1登录界面
  • linux防止攻击
  • gnaupdaemon.exe是什么
  • winxp如何进入bios
  • 为啥没有win8 win9
  • win7系统可移动的文件
  • windows7的开机启动项在哪里
  • iwatch命名
  • python基础总结
  • vue组件互相嵌套
  • linux查看远程服务是否开启
  • nodejs怎么启动服务
  • 深入理解javascript
  • jquery获取自定义标签的值
  • 安卓接口分类
  • jquery的哪个方法可以绑定mouseover
  • 住房货币化什么意思
  • 职工教育经费可以结转吗
  • 怎样在中国税务用手机交社保
  • 出口退税注销怎么办理
  • 简述纳税人与负税的区别
  • 房屋契税可以退个人所得税吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设