Dom-to-image js 库问题

问题描述

我正在编写一个函数来使用 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关键字后它在不同浏览器中的表现异常。

预期输出

enter image description here

Mozilla Firefox 中的输出

enter image description here

Chrome 中的输出

enter image description here

这里使用单独的div来显示所有内容, 例如:

<div id="name" style="top:103px;left:83px">name</div>
<div id="dob" style="top:200px;left:83px">dob</div>

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)