解决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);
    }
}
相关推荐
2501_916008891 小时前
Web 前端开发常用工具推荐与团队实践分享
android·前端·ios·小程序·uni-app·iphone·webview
2501_915921431 小时前
“HTTPS 个人化”实战,个人站点与设备调试的部署、验证与抓包排查方法
网络协议·http·ios·小程序·https·uni-app·iphone
SkylerHu1 小时前
前端代码规范:husky+ lint-staged+pre-commit
前端·代码规范
菜鸟una2 小时前
【微信小程序 + 消息订阅 + 授权】 微信小程序实现消息订阅流程介绍,代码示例(仅前端)
前端·vue.js·微信小程序·小程序·typescript·taro·1024程序员节
Yeats_Liao2 小时前
Go Web 编程快速入门 05 - 表单处理:urlencoded 与 multipart
前端·golang·iphone
飞翔的佩奇2 小时前
【完整源码+数据集+部署教程】【运动的&足球】足球场地区域图像分割系统源码&数据集全套:改进yolo11-RFAConv
前端·python·yolo·计算机视觉·数据集·yolo11·足球场地区域图像分割系统
拉不动的猪2 小时前
h5后台切换检测利用visibilitychange的缺点分析
前端·javascript·面试
桃子不吃李子2 小时前
nextTick的使用
前端·javascript·vue.js
萌新小码农‍2 小时前
SpringBoot+alibaba的easyexcel实现前端使用excel表格批量插入
前端·spring boot·excel
冰暮流星3 小时前
css3新增背景图片样式
前端·css·css3