<div class="QR-code" id="QR-code">
<div id="qrcode" ref="qrCodeDiv" class="qrCode" style="margin:0 auto"></div>
</div>
<div class="btn-content">
<a class="btn btn-right" v-on:click="downQrcode1()">
<i class="icon iconfont"></i>
下载
</a>
</div>
downQrcode1() {
let myCanvas = document.getElementById('qrcode').getElementsByTagName('canvas');
let img=document.getElementById('qrcode').getElementsByTagName('img')
let a= document.createElement("a")
let imgURL=myCanvas[0].toDataURL('image/jpg');
let ua = navigator.userAgent;
if (ua.indexOf("Trident") != -1 && ua.indexOf("Windows") != -1) {
var bstr = atob(imgURL.split(',')[1])
var n = bstr.length
var u8arr = new Uint8Array(n)
while (n--) {
u8arr[n] = bstr.charCodeAt(n)
}
var blob = new Blob([u8arr])
window.navigator.msSaveOrOpenBlob(blob, '下载' + '.' + 'png')
}else if(ua.indexOf("Firefox") > -1){
let blob = this.base64ToBlob(imgURL);
let evt = document.createEvent("HTMLEvents");
evt.initEvent("click", true, true);
a.download = ' ';
a.href = URL.createObjectURL(blob);
a.dispatchEvent(new MouseEvent('click', {bubbles: true, cancelable: true, view: window}));
}else{
img.src=myCanvas[0].toDataURL('image/jpg');
a.href=img.src
a.download = "下载"
a.click()
}
},
base64ToBlob(code) {
let parts = code.split(';base64,');
let contentType = parts[0].split(':')[1];
let raw = window.atob(parts[1]);
let rawLength = raw.length;
let uInt8Array = new Uint8Array(rawLength);
for (let i = 0; i < rawLength; ++i) {
uInt8Array[i] = raw.charCodeAt(i);
}
return new Blob([uInt8Array], {type: contentType});
},