解决 html2canvas 转图片时不显示网络图片的问题

业务场景:需要将div元素转成一张图片,div元素里面包含img标签,加载一张网络图片。

问题:正常转换成图片的话,网络图片显示不出来,其余元素都能按样式正常显示,后来经测试如果加载本地图片,也能正常显示,于是就想办法将网络图片变成本地图片(base64二进制)。

解决方案:网络图片变成本地图片(base64二进制)

//将网络图片转成本地图片
function getBase64Image(url) {
    var image = new Image()
    image.src = url + '&v=' + Math.random() // 处理缓存
    image.crossOrigin = '*' // 支持跨域图片
    image.onload = function () {
        $(".invit_info_qrcode").attr("src",drawBase64Image(image))
        convertDivToImage("my_div")
    }
}

//将图片转成base64,返回字符串
function drawBase64Image(img) {
    var canvas = document.createElement('canvas')
    canvas.width = img.width
    canvas.height = img.height
    var ctx = canvas.getContext('2d')
    ctx.drawImage(img, 0, 0, img.width, img.height)
    var dataURL = canvas.toDataURL('image/png')
    return dataURL
}

//转换图片,传入元素id
function convertDivToImage(divId) {
    const $element = $('#' + divId);
    $element.css('background-color', '#fff')
    html2canvas($element[0]).then((canvas) => {
        const imgData = canvas.toDataURL('image/png');
        const imgEle = $('#review').attr('src', imgData).attr('width',    canvas.width).attr('height', canvas.height);
        $element.replaceWith(imgEle);
    });
}

贴出核心代码,自己研究吧

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值