当前位置: 首页 > news >正文

广州电玩网站开发商丘哪里教做网站的

广州电玩网站开发,商丘哪里教做网站的,企企管理云平台,遵义建设厅网站#x1f680; 场景一#xff1a;利用vue向pdf文件中写入二维码图片或其他图片 #x1f680; 场景二#xff1a;向pdf中添加水印 思路#xff1a; 1、先通过url链接生成二维码#xff0c;二维码存在于dom中 2、使用html2canvas库将二维码的dom转为一个canvas对象 3、根据c… 场景一利用vue向pdf文件中写入二维码图片或其他图片 场景二向pdf中添加水印 思路 1、先通过url链接生成二维码二维码存在于dom中 2、使用html2canvas库将二维码的dom转为一个canvas对象 3、根据canvas对象获取blob中的buffer 4、最后将这个二维码以图片的形式嵌入到pdf文件流中 安装依赖 npm i html2canvas npm i qrcodejs2-fixes npm i pdf-lib引入 import html2canvas from html2canvas import QRCode from qrcodejs2-fixes import { degrees, PDFDocument } from pdf-lib封装 封装qrToPdf.js用的时候直接调用该方法将pdf文件流blob对象和二维码url链接地址传入进去 就可以我这里就以window打开一个新页签预览处理之后的pdf为例了真实项目也可能是下载都是差不多的下载也很简单通过a标签window.URL.createObjectURL转为一个路径然后给a标签增加download属性值为文件名称click即下载了 src/utils/qrToPdf.js import html2canvas from html2canvas import QRCode from qrcodejs2-fixes import { degrees, PDFDocument } from pdf-libexport default function ({ pdfBlob, qrcodeUrl https://www.baidu.com/ }) {if(!pdfBlob) returnpdfBlob.arrayBuffer().then(async buffer {const pdfDoc await PDFDocument.load(buffer)const qrcodeDom document.createElement(div)qrcodeDom.id wft-qrcodedocument.body.appendChild(qrcodeDom)new QRCode(document.getElementById(wft-qrcode), {text: qrcodeUrl,width: 128,height: 128,colorDark: #000000,colorLight: #ffffff,correctLevel: QRCode.CorrectLevel.H,})html2canvas(document.getElementById(wft-qrcode)).then(canvas {canvas.toBlob(qrcodeBlob {qrcodeBlob.arrayBuffer().then(async qrcodeBuffer {const image await pdfDoc.embedPng(qrcodeBuffer)const dims image.scale(0.6)const pages pdfDoc.getPages()for (let i 0; i pages.length; i) {let page pages[i]const { width, height } page.getSize()page.drawImage(image, {x: width - 100, // 距离右侧100y: height - 100, // 距离上侧100 就是右上角width: dims.width,height: dims.height,rotate: degrees(0)})}const pdfBytes await pdfDoc.save()preView(pdfBytes)document.body.removeChild(qrcodeDom)})}, image/png)})}) }// 打开新页签预览 function preView(stream, docTitle 测试PDF) {const URL window.URL || window.webkitURL;// href 就是生成的pdf地址可以拿到href做不通操作下载预览等等const href URL.createObjectURL(new Blob([stream], { type: application/pdf;charsetutf-8 }))const wo window.open(href)// 设置新打开的页签 document titlelet timer setInterval(() {if (wo.closed) {clearInterval(timer)} else {wo.document.title docTitle}}, 500) }引入调用使用的时候 previewEmbedQrcodeToPdf({pdfBlob: file, // 你的文件流qrcodeUrl: xxxx // 你的生成二维码的url链接 })案例(Vue3) vue2大致写法都一样 templatediv classmaininput idfileInp typefile/div /template script setup import { onMounted, onUnmounted } from vue import previewEmbedQrcodeToPdf from /utils/qrToPdflet cusInp nullonMounted(() {cusInp document.getElementById(fileInp)cusInp.addEventListener(input, inpHander) })onUnmounted(() {cusInp.removeEventListener(input, inpHander) })function inpHander(event) {const file event.target.files[0]if(!file) returnpreviewEmbedQrcodeToPdf({pdfBlob: file}) } /script style scoped .main {width: 100%;height: 100%; } /style合成预览图 此博客主要参考https://blog.csdn.net/m0_51431448/article/details/131216664 Vue向Pdf添加水印https://blog.csdn.net/m0_51431448/article/details/129539428?spm1001.2014.3001.5501
http://www.dnsts.com.cn/news/20479.html

相关文章:

  • 公司网站英文域名在哪查怎样做服装厂的企业网站模版
  • 摄像头做直播网站长春哪家网站做的好
  • 网站建设怎么谈要做网站
  • 做网站推广需要多少钱高端网站建设步骤
  • c语言做网站吗金蝶erp软件
  • 织梦高端html5网站建设工作室网络公司网站模板凡科企业网站如何建设
  • 做网站的公司怎么推销四子王旗建设局网站
  • 壹像素网站帝国网站认证码
  • 建筑工程网上流程工作失误随州seo推广
  • 湖北金扬建设网站软件企业
  • 电子商务网站管理系统网站建设 职责
  • 山东外贸建站平面设计模板素材网站
  • 宝安建设网站用狐狸做logo的网站
  • 中国建设银行总行官方网站jsp电子商务网站建设实验
  • 重庆做网站泉州公司南宁百度seo排名价格
  • 金顶街网站建设西安做软件的公司
  • 科院公司网站建设目标是什么计算机大专学历有用吗
  • 桂林网站优化公司网站跟客户端推广怎么做
  • 国内做网站的龙头企业调用wordpress搜索代码
  • 广州网站建设大公司排名wordpress.html
  • 静态做网站河南省建设厅网站资质平移办法
  • vue做响应式网站我要表白网站
  • php网站后台忘记密码昌邑营销型网站建设
  • 网站备案ip地址wordpress摄影公司
  • 网站描述案例黄埔做网站的公司
  • 网站排队队列怎么做电脑公司网站模板
  • 哪个网站使用vue 做的录像网站怎么做
  • 网站设计平台大连建设网节能办公室网站
  • 两人合伙做网站但不准备开公司如何恢复wordpress
  • 网站改版是什么意思网站管理建设落实报告