domToImage使用补充 toBlob canvas过大

本文记录了一个前端开发中遇到的问题,即在使用domToImage库将Kendo Grid组件转换为图片并尝试下载时,由于DOM元素过大导致canvas.toBlob返回null。通过参考相关博客和同事的帮助,找到了一种成功解决该问题的方法,但具体原因尚未明确。
摘要由CSDN通过智能技术生成

需求:点击截屏按钮将表格(grid)组件内容以图片形式下载下来形成截屏

背景:kendo grid组件;公司已有grid转screenshot先例,cv时发现下载不下来,toBlob返回为null

import domtoimage from 'dom-to-image';
import { saveAs } from 'file-saver';

export function transDomToImage (node, name) {
    domtoimage.toBlob(node).then(blob => {
       if (blob) saveAs(blob, `{name}.png`)
    })
}
transDomToImage(this.elementRef.nativeElement, name)

解决过程:参考Ref2感觉可能因为grid的dom太大了?但是之前公司的那个grid更大,用这个也没问题。请教同事姐姐之后得出解决方案:

transDomToImage(this.elementRef.nativeElement.querySelector('kendo-grid'), name)

但是至今没懂为什么这样会成功´・_・)?

Ref:

dom-to-img 学习记录(网页截屏)_蜗牛码农路的博客-CSDN博客

canvas.toBlob bug_qiphon3650的博客-CSDN博客_canvas toblob

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值