vue二维码生成插件qrcodejs2-fix、html生成图片插件html2canvas、自定义打印内容插件print-js的使用及问题总结

一、二维码生成插件qrcodejs2-fix

1.安装命令

javascript 复制代码
npm i qrcodejs2-fix --save

2.页面使用

javascript 复制代码
import { nextTick } from 'vue';
import QRCode from 'qrcodejs2-fix';
nextTick(() => {
	let codeView = document.querySelector("#codeView");
	codeView.innerHTML = "";
	new QRCode(codeView, {
	    text: '测试内容', // 二维码内容
	    width: 220, // 二维码图片宽度
	    height: 220, // 二维码图片高度
	})
})

注意:若未生成二维码,可能是因为标签还未加载完,需要时可使用nextTick。

二、html生成图片插件html2canvas

1.安装命令

javascript 复制代码
npm i html2canvas --save

2.页面使用

javascript 复制代码
html2canvas(document.querySelector('#codeViewBox'), {
   useCORS: true, // 是否尝试使用CORS从服务器加载图像
   timeout: 1000,
   scale: 1.3, // 用于渲染的比例,默认为浏览器设备像素比率。
   allowTaint: true, // 是否允许跨源图像污染画布
   width: 450, // 画布的宽度
   height: 800 // 画布的高度
}).then(canvas => {
    let imgData = canvas.toDataURL('image/jpg');
  	console.log(imgData);
  	// data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAB...
})

可能会遇到的问题:

1.若二维码插件和生成图片插件一起使用,生成图片时只有二维码没有其他内容,是因为二维码插件生成时会创建canvas标签,html生成图片时也会创建canvas标签,插件获取标签的时候可能会混淆,可以在html2canvas()方法使用前加上下面两句代码(二维码插件会生成一个canvas标签和一个img标签,移除二维码标签中的canvas标签,保留img标签即可)。

javascript 复制代码
let _canvas = document.querySelector("#codeView canvas");
document.querySelector("#codeView").removeChild(_canvas);

2.生成的图片内容会根据屏幕宽高适配不同的大小,比如app端打印的图片内容大小正常,但是到pc端字体和图片会放大很多倍。这种情况应该是项目加了全局的rem布局适配,需要取消生成图片内容标签的适配转换。像我的项目为了做适配引入了postcss-pxtorem插件,需要在配置文件vue.config.js 或 vite.config.js里面定义一个忽略的类名前缀,然后给需要html标签上面加上这个类名前缀。这样有这个类名前缀的标签就不会做rem转换了,保证了在不同大小屏幕下生成的图片比例一致。

javascript 复制代码
<div class="printCont-Box" >...图片内容...</h5>

3.一开始没有给html2canvas传配置参数,在pc端调试的一切都正常,后来用安卓机调试发现生成的图片字节很小,图片空白的没有任何内容,后来加了上面一些配置才正常了。

注:本文只列举了一些常用的参数配置,如有需要可访问下方地址查看更多信息。
https://html2canvas.hertzen.com/

三、自定义打印内容插件print-js

1.安装命令

javascript 复制代码
npm i print-js --save

2.页面使用

javascript 复制代码
import printJs from 'print-js';
printJs({
    printable: 'id01', // 文档来源:pdf或图片url、html元素id、json数据对象
    type: 'html', // 可选:pdf、html、image、json、raw-html
    css: '/css/commom.less', // css文件的URL(单个URL字符串或多个URL的数组)
    style: 'body {padding: 30px;};', // 自定义样式的字符串
    maxWidth: 1000, // 最大文档宽度(以像素为单位)
});

注:本文只列举了一些常用的参数配置,如有需要可访问下方地址查看更多信息。
https://printjs.crabbly.com/

相关推荐
csdn_aspnet9 分钟前
Asp.Net Core 10.0 中的 Blazor 增强功能
前端·后端·asp.net·blazor·.net10
SuperEugene10 分钟前
Excel 上传解析 + 导出实战:Vue+xlsx 避坑指南|Vue生态精选
前端·javascript·vue.js·excel·xlsx·vxetable
小马_xiaoen15 分钟前
常规优化已用尽?小程序体积深层次优化实战!!!
前端·小程序·uniapp
Highcharts.js15 分钟前
使用Highcharts创建流图(Stream Graph)指南|流动数据的可视化图表与数据艺术表达
javascript·信息可视化·数据可视化·highcharts·可视化图表·流图·stream graph
Lee_Yu_Fan18 分钟前
修改ElementUI 框架中 TreeSelect树形选择的Icon
前端·elementui
C澒21 分钟前
解决多市场业务复用与差异化痛点:Vue Composition API 分层架构方案
前端·架构·前端框架
极客小俊22 分钟前
【H5 前端开发笔记】第 03 期:HTML的历史、书写规范与文档类型声明<!DOCTYPE> 详解
html·学习笔记·前端开发·编程基础·免费教程·html文档类型声明·零基础学习
努力往上爬de蜗牛24 分钟前
el-table列表修改某个输入框输入 卡顿问题修改
javascript·vue.js·elementui
深念Y24 分钟前
一个Bug:Vue Router 4.3.0 导致浏览器窗口无法最小化
前端·vue.js·bug·窗口·最小化·bilibili·视频网站
湛海不过深蓝25 分钟前
【procomponents】根据表单查询表格数据的两种写法
前端·javascript·react.js