问题描述
我正在编写一个函数来使用 dom-to-image 将我的 dom(带有 id 内容的 div)渲染为 png 图像并在渲染后上传到我的服务器,因此引入了一个异步函数以等待完成图像处理,但是在介绍,它在不同浏览器中呈现异常。 我的渲染图像代码:
function PrintDiv(div,type) {
return new Promise((resolve) => {
imgf.src = '';
var node = document.getElementById(div);
const scale = 3;
var options = {
height: node.offsetHeight * scale,width: node.offsetWidth * scale,style: {
transform: "scale(" + scale + ")",transformOrigin: "top left",width: node.offsetWidth + "px",height: node.offsetHeight + "px"
}
};
domtoimage.toPng(node,options).then(function (dataUrl) {
imgf.src = dataUrl;
resolve(true);
}).catch(function (error) {
console.error('oops,something went wrong!',error);
resolve(false);
});
});
}
驱动程序代码:
async function savetoserver(){
if(document.getElementById("sphoto").complete){
let isImageProcessed=await PrintDiv('content',1);
if(isImageProcessed){
// excecute uploading
}else{
//image process Failed
savetoserver();
}
}
}
在将函数savetoserver更改为async之前,它正在处理正确的图像,但是在添加async关键字后它在不同浏览器中的表现异常。
预期输出:
Mozilla Firefox 中的输出:
Chrome 中的输出:
<div id="name" style="top:103px;left:83px">name</div>
<div id="dob" style="top:200px;left:83px">dob</div>
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)