最近踩得坑比较多,记录一下BUG出现过程
原因是公司要求在公众号展示出相关机构的报告,将页面转为图片并附带二维码,在pc端时候,QRCode与domtoimage并不会出现问题,但我将代码提交服务器,并用手机微信查看的时候,发现在微信公众号中domtoimage插件生成失败了。
解决思路与办法就是先使用QRcode生成二维码,生成二维码后,需要在二维码生成的方法后面加入下面的代码
var img = document.getElementById("twoCode").getElementsByTagName("img")[0]document.getElementById("twoCode").removeChild(img);
this.$nextTick(()=>{
this.imgCreate();
})
twoCode为二维码的id名,img则是为了删除标签,this.$nextTick方法里面是domtoimage转图片的方法,顺序不能乱
除了这里需要注意还需要修改QRCode源码中的代码,找到插件中qrcode.js文件
function _onMakeImage() {
this._elImage.src = this._elCanvas.toDataURL("image/png");
this._elImage.style.display = "block";
this._elCanvas.style.display = "none";
}
我这里显示是第 289行,找到这段代码将this._elCanvas.style.display = “none”;替换为block
到此为止大功告成!
还有另一种情况就是img图片的src动态引入http外部链接时报错的问题,这个需要在标签内添加 crossorigin="anonymous"
,在src的链接后面添加‘?any_string_is_ok’
,这样就能在微信内正常使用domtoimage了
:附完整img
<img crossorigin="anonymous" :src="patient.hospitalLogo ? patient.hospitalLogo + '?any_string_is_ok':''" />