解決qrcode.js生成二維碼時必須定義一個空div的問題
根據(jù)qrcode的文檔說明:https://github.com/davidshimjs/qrcodejs
<div id="qrcode"></div>
<script type="text/javascript">
new QRCode(document.getElementById("qrcode"), "sample text");
// or
new QRCode(document.getElementById("qrcode"), {
text: 'sample text',
width: 200,
height: 200,
colorDark: "#000000",
colorLight: "#ffffff",
correctLevel: QRCode.CorrectLevel.H
});
要有一個元素存放二維碼,
可以看到這個div中被追加了canvas,img兩個標簽。
但是我想不想創(chuàng)建這個div啊。然后我就找到了node-qrcode
他有兩種用法:
<html>
<body>
<canvas id="canvas"></canvas>
<script src="bundle.js"></script>
</body>
</html>
<script>
var QRCode = require('qrcode')
var canvas = document.getElementById('canvas')
QRCode.toCanvas(canvas, 'sample text', function (error) {
if (error) console.error(error)
console.log('success!');
})
</script>
很顯然這種和前面那個一樣,需要先創(chuàng)建一個標簽。
var QRCode = require('qrcode')
QRCode.toDataURL('I am a pony!', function (err, url) {
console.log(url)
})
終于找到我想要的了,不過,這里的url是base64,如果二維碼過大的話,使用base64進行圖片渲染,會導(dǎo)致瀏覽器崩潰,這個問題后面解決。
那么問題又來了,這個node-qrcode只能用在vue中使用(不能直接在瀏覽器運行,需要特殊處理),如果想直接使用(或在vue中使用cdn)必須用第一種模式。
這問題有繞回來了。
暫時沒有好的方案。自己二次優(yōu)化一下吧。
既然第一種方案里,有一個img標切,是不是可以讀取圖片流,然后自己處理?
var div = document.createElement('div');
var size = 200;
var padding = 20;
var bg = '#ffffff';
new QRCode(div, {
text: val,
width: size,
height: size,
colorDark: "#000000",
colorLight: bg,
correctLevel: QRCode.CorrectLevel.H
});
console.log(div.querySelector('img').src);
發(fā)現(xiàn)是空的''.
根據(jù)以往經(jīng)驗,這里的圖片,可能需要時間來渲染?
div.querySelector('img').addEventListener('load', (event) => {
var img = event.target;
console.log(img.src);
})
果然拿到了base64地址。
到此,就已經(jīng)解決所有問題,剩下的,就是自己畫個二維碼了(這種方法生成的二維碼,沒有邊距留白,非常丑)
// https://github.com/davidshimjs/qrcodejs
export default {
imageBase64ToBlob(urlData, type = 'image/jpeg') {
var ab = null;
try {
var arr = urlData.split(',')
var mime = arr[0].match(/:(.*?);/)[1] || type;
// 去掉url的頭,并轉(zhuǎn)化為byte
var bytes = window.atob(arr[1]);
// 處理異常,將ascii碼小于0的轉(zhuǎn)換為大于0
ab = new ArrayBuffer(bytes.length);
// 生成視圖(直接針對內(nèi)存):8位無符號整數(shù),長度1個字節(jié)
var ia = new Uint8Array(ab);
for (var i = 0; i < bytes.length; i++) {
ia[i] = bytes.charCodeAt(i);
}
return new Blob([ab], {
type: mime
});
} catch (e) {
ab = new ArrayBuffer(0);
return new Blob([ab], {
type: type,
});
}
},
createQr(val, back) {
var div = document.createElement('div');
var size = 200;
var padding = 20;
var bg = '#ffffff';
new QRCode(div, {
text: val,
width: size,
height: size,
colorDark: "#000000",
colorLight: bg,
correctLevel: QRCode.CorrectLevel.H
});
var canvas = div.querySelector('canvas');
div.querySelector('img').addEventListener('load', (event) => {
var img = event.target;
var ctx = canvas.getContext('2d');
ctx.fillStyle = bg;
ctx.fillRect(0, 0, size, size);
// ctx.clearRect(0, 0, size, size);
ctx.drawImage(img, 0, 0, img.width, img.height, padding, padding, size - 2 * padding, size - 2 * padding);
let url = canvas.toDataURL();
back(URL.createObjectURL(this.imageBase64ToBlob(url)))
})
}
}
到此這篇關(guān)于解決qrcode.js生成二維碼時必須定義一個空div的問題的文章就介紹到這了,更多相關(guān)qrcode.js二維碼定義一個空div內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
以WordPress為例講解jQuery美化頁面Title的方法
鼠標移動到超鏈接時顯示Title提示即是所謂Title美化的一般手段,這里我們就以WordPress為例講解jQuery美化頁面Title的方法,需要的朋友可以參考下2016-05-05

