嗨,我在puppeteersharp中抓取了一个网页,并使用下面的脚本在画布项目上获取图像,因为获取元素不会返回其中的背景图像:
var canvasItem = await reactElement.QuerySelectorAllAsync("canvas.flot-base");
string canvasImage = "";
if(canvasItem!=null)
foreach(var canvas in canvasItem)
{
canvasImage+=await canvas.EvaluateFunctionAsync("e=>e.toDataURL()");
await canvas.EvaluateFunctionAsync($"(e,{canvasImage})=>{var ctx=e.getContext('2d');var img=new Image(); img.onload=function(){ctx.drawImage(img,0,0);};img.src=canvasImage}", canvasImage);
}
base64字符串成功返回,但我不知道它是否是传递给evaluateFunctionAsync()脚本的正确方法。有人能给我解释一下吗?亲切的问候
你不需要这些括号。
await canvas.EvaluateFunctionAsync(@"(e, canvasImage)=> {
var ctx=e.getContext('2d');
var img=new Image();
img.onload=function() {
ctx.drawImage(img,0,0);};
img.src=canvasImage
}
}", canvasImage);