关于DOM如何使用html2canvas生成base64编码

1、安装html2canvas: npm install --save html2canvas

2、引入html2canvas: import html2canvas from 'html2canvas'

3、封装方法:

export const domCreateBase64 = (domCopy) => {
  return new Promise(async (resolve, reject) => {
    const body = document.body
    body.appendChild(domCopy)
    setTimeout(() => {
      html2canvas(domCopy, {
      // 提升截图效率,将不需要的元素忽略 
        scale: 1, ignoreElements: el => { 
          if (el == domCopy) return false;
          if (el.tagName == 'BODY') return false;
          if (el.tagName == 'HEAD') return false;
          if (domCopy.compareDocumentPosition(el) == 20) return false;
          if (el.tagName == 'STYLE') return false;
          if (el.id == 'app') return false;
          if (el.tagName == 'LINK') {
            if (/\.js$/.test(el.href)) return true;
            else return false;
          }
          if (el.tagName == 'SCRIPT') return true;
          if (el.classList.contains('scene')) return true
          return true
        }
      }).then(canvas => {
        body.removeChild(domCopy)
        //导出生成的base64编码
        resolve(canvas.toDataURL('image/png'))
      })
    }, 300)
  })  
}

4、引入domCreateBase64 方法

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值