解决html-to-image在 ios 上dom里面的图片不显示出来

原因:在iOS的Safari浏览器,使用页面生成图片,如dom里面有图片,则会先进行加载资源,但是这个加载速度会随着图片大小而延长,但是页面生成图片的时机总会比这个快。所以会导致dom里面的图片不会出来

解决方案:这里我是用了vue3。

javascript 复制代码
const captureSnapshot = async (targetElement,options,previousDataUrl = "") => {
  const dataUrl = await htmlToImage.toPng(targetElement,options)

  // 这是判断因为 dataUrl 对快照图像进行了编码,而 Safari 现在渲染的内容比上次更多。dataUrl 的长度提供了一些关于渲染内容的信息。直到dataUrl.length停止增加,表明 Safari 已完成渲染。
  return (dataUrl.length !== previousDataUrl.length)
    ? captureSnapshot(targetElement,options,dataUrl)
    : dataUrl
}

// 页面上传图片
const generateReport = () => {
    let offscreenContainer = document.getElementById('my-node');

    // 这个options无所谓,主要是captureSnapshot方法和下面给img加上decoding="sync"属性
    let options = {
        quality: 0.95,
        backgroundColor: '#ffffff',
        width: offscreenContainer.scrollWidth,
        height: offscreenContainer.scrollHeight,
        pixelRatio: window.devicePixelRatio > 2 ? 2 : window.devicePixelRatio,
        filter: function (node) {
            if (node.tagName === 'IMG' && (!node.src || node.src === '')) {
                return false;
            }
            if (node.classList && node.classList.contains('landscape-wrap')) {
                return false;
            }
            if (node.classList && node.classList.contains('link-more')) {
                return false;
            }
            return true;
        },
        canvasTimeout: 15000,
        useCORS: true,
        skipAutoScale: true,
        allowTaint: true,
        // iOS兼容性设置
        preferredFontFormat: 'woff2',
        skipFonts: false,
        style: {
            transform: 'scale(1)',
            transformOrigin: 'top left'
        },
    };

    try {
        // 确保所有图表都已渲染完成
        await nextTick();

        // 这个也是关键代码。给offscreenContainer里面的img添加decoding="sync"属性,不然ios上还是会显示不出dom里面的图片
        offscreenContainer.querySelectorAll('img').forEach(img => {
            img.setAttribute('decoding', 'sync');
        });
        
        // 转换为png格式
        imgSrc.value = await captureSnapshot(offscreenContainer,options);

    } catch (error) {
        console.error('生成失败:', error);
    }
}
相关推荐
gnip20 小时前
Jst执行上下文栈和变量对象
前端·javascript
excel20 小时前
🐣 最简单的卷积与激活函数指南(带示例)
前端
醉方休21 小时前
npm/pnpm软链接的优点和使用场景
前端·npm·node.js
拉不动的猪21 小时前
简单回顾下Weakmap在vue中为何不能去作为循环数据源,以及替代方案
前端·javascript·vue.js
How_doyou_do21 小时前
数据传输优化-异步不阻塞处理增强首屏体验
开发语言·前端·javascript
奇舞精选21 小时前
超越Siri的耳朵:ASR与Whisper零代码部署实战指南
前端·人工智能·aigc
奇舞精选21 小时前
Nano Banana 如何为前端注入 AI 控制力
前端·aigc
一支鱼21 小时前
基于 Node.js 的短视频制作神器 ——FFCreator
前端·node.js·音视频开发
DT——1 天前
前端登录鉴权详解
前端·javascript
李姆斯1 天前
复盘上瘾症:到底什么时候该“复盘”,什么时候不需要“复盘”
前端·后端·团队管理