日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

生成二维码压缩文件

發(fā)布時間:2023/12/31 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 生成二维码压缩文件 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

生成二維碼壓縮文件

https://pan.baidu.com/s/1_m3ZYTtDhXFUDCXaX2u1Uw
依賴地址(提取碼:Lazy)

  • 引入文件
  • <script src="./js/jszip.min" type="text/javascript" charset="utf-8"></script> <script src="./js/filesaver.min" type="text/javascript" charset="utf-8"></script> <script src="./js/jquery-3.6.0.min" type="text/javascript" charset="utf-8"></script> <script src="./js/qrcode.min" type="text/javascript" charset="utf-8"></script>
  • 創(chuàng)建一個全局畫布
  • var canvas = document.createElement('canvas'); //創(chuàng)建一個全局畫布canvas.width = 300; //設(shè)置畫布的寬和高canvas.height = 400;var ctx = canvas.getContext('2d'); //畫筆
  • 生成打包
  • async saveSome(list) { //生成多個并打包下載到本地for (let i = 0; i < list.length; i++) {let item = list[i];await this.draw(item); //等待繪圖await this.addToZip(canvas, zip, item.stuName + ".png"); //等待加入zip文件}this.createZip() //創(chuàng)建ZIP文件},
  • 創(chuàng)建,繪圖,下載
  • draw(item) { //繪制二維碼及名字標(biāo)識return new Promise((resolve, reject) => {var div = document.createElement('div');var qrcode = new QRCode(div, { //繪制二維碼text: item.qrcode, //二維碼名字,可以看出來區(qū)別width: 250,height: 250,colorDark: "#000000",colorLight: "#ffffff",correctLevel: QRCode.CorrectLevel.H});let mc = div.querySelector('canvas');ctx.beginPath(); //開始繪制ctx.fillStyle = '#FFFFFF';ctx.fillRect(0, 0, 300, 400) //填充底色ctx.drawImage(mc, 25, 25) //繪制二維碼ctx.font = "bold 45px 微軟雅黑";ctx.textAlign = "center";ctx.textBaseline = "middle";ctx.fillStyle = '#000000';ctx.fillText(item.stuName, 150, 350) //繪制文字在底部ctx.closePath(); //結(jié)束繪制resolve();})},async createZip() { //下載zip文件到本地zip.generateAsync({type: 'blob'}).then(function(content) {saveAs(content, `XXX_${new Date().getTime()}.zip`);});},addToZip(canvas, zip, name) {return new Promise((resolve, reject) => {canvas.toBlob(function(blob) {zip.file(name, blob); // 將每次不同的canvas數(shù)據(jù)添加到zip文件中resolve();});})},
  • 調(diào)用函數(shù)
  • getQRCode(data).then(res => {this.saveSome(res.data).then(res => {setTimeout(function(){location.reload()},2000)})})

    總結(jié)

    以上是生活随笔為你收集整理的生成二维码压缩文件的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。