使用html2Canvas生成图片跨域如何处理?

使用html2Canvas生成图片跨域如何处理?,第1张

1.出现跨域的情况

这种情况只会出现在html2Canvas需生成的海报中的图片与当前环境不在同一个域下

2.解决方案

处理跨域,将接口返回的url处理为base64再进行处理或者后端直接返回base64

3.如何将url转换为base64?(利用canvas的toDataURL属性将url转为base64)

  function getImageBase64Data(imgSrc) {

    function getBase64(img) {

      let canvas = document.createElement("canvas")

      canvas.width = img.width

      canvas.height = img.height

      let ctx = canvas.getContext("2d")

      ctx.drawImage(img, 0, 0, canvas.width, canvas.height)

      let dataURL = canvas.toDataURL('image/jpeg')

      return dataURL

    }

    let baseUrl = new Promise(function (resolve, reject) {

      let image = new Image()

      image.crossOrigin = '*'// 图片处理跨域

      if (imgSrc.indexOf('data:image/jpegbase64') >-1) {

        image.src = imgSrc + '?v=' + Math.random()// 处理图片从缓存获取

      } else {

        image.src = imgSrc

      }

      image.onload = function () {

        let imageBase64Data = getBase64(image)

        resolve(imageBase64Data)

      }

    })

    return baseUrl

  }

4.使用html2Canvas生成海报

  const download = () => {

    let content = document.getElementById('promote-content')

    if (content) {

      html2canvas(content, { useCORS: true, allowTaint: true }).then(res => {

        const imgBase64 = res.toDataURL('image/jpeg')

        let link = document.createElement('a')

        link.style.display = 'none'

        link.href = imgBase64

        link.setAttribute('download', name + moment().format('YYYYMMDDHHmm'))

        document.body.appendChild(link)

        link.click()

        document.body.removeChild(link)

      })

    }

  }

INPUT type=image 元素

创建一个图像控件,该控件单击后将导致表单立即被提交。

支持的格式有:

.avi - 交错音频视频 (AVI)

.bmp - Windows 位图 (BMP)

.emf - Windows 增强图元文件 (EMF)

.gif - 图像交换格式 (GIF)

.jpg, .jpeg - 移动图像专家组 (JPEG)

.mov - Apple QuickTime 电影 (MOV)

.mpg, .mpeg - 移动图像专家组 (MPEG)

.png - 便携网络图像 (PNG)

.wmf - Windows 图元文件 (WMF)

.xbm - X 位图 (XBM)

参考DHTML手册

有不明白的,百度消息我,一起解决


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6263901.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-19
下一篇 2023-03-19

发表评论

登录后才能评论

评论列表(0条)

保存