使用dom-to-image截图html区域为一张图

第一步安装npm i dom-to-image
第二步引入: import domToImage from 'dom-to-image';
第三步截图:

javascript 复制代码
// 截图
function screenshot() {
  return new Promise((resolve, reject) => {
    const images = document.querySelectorAll('.isCrossOrigin'); //给需要截图的图片都加上clss名称便于获取
    const videos = imageWrapper.value.querySelectorAll('video'); // 获取画布下所有视频元素
    // 隐藏所有视频元素,因为截出来的视频是黑屏
    videos.forEach((video) => {
      video.style.display = 'none';
    });
    images.forEach((img) => {
      // 保存原始的图片地址
      const originalSrc = img.getAttribute('src');
      // 移除 src 属性,设置 crossOrigin解决图片跨域,然后再设置 src
      img.removeAttribute('src');
      img.crossOrigin = 'anonymous';
      img.src = originalSrc;
    });
    domToImage.toBlob(imageWrapper.value, {
      cacheBust: true,  //添加 cacheBust 选项以确保不会使用缓存图片
      width: bgSrcWidth.value,
      height: bgSrcHeight.value,
    })
      .then(function (blob) {
        // 截图成功后,去除跨域设置
        images.forEach((img) => {
          img.removeAttribute('crossOrigin');
        });
        // 显示视频元素
        videos.forEach((video) => {
          video.style.display = 'block';
        });
        const formData = new FormData();
        formData.append('file', blob, 'image.png');
        uploadBgImg(formData).then((res) => {
          resolve(res.data)
        })
      }).catch((err) => {
        // 如果出现错误,去除跨域设置并恢复所有视频元素
        images.forEach((img) => {
          img.removeAttribute('crossOrigin');
        });
        videos.forEach((video) => {
          video.style.display = 'block';
        });
        reject(err);
      })
  })
}

缺点:截图时间特别长,视频截图是黑屏,暂时还没解决,大家有解决的欢迎指正~

相关推荐
openKaka_14 分钟前
从 performWorkOnRoot 到 workInProgress tree:React 真正开始 render 的地方
前端·javascript·react.js
invicinble27 分钟前
前端框架使用vue-cli( 第四层:业务源码层--登陆页相关)
前端·vue.js·前端框架
Rooting++27 分钟前
vue2强制刷新路由的办法
前端·javascript·vue.js
nunumaymax30 分钟前
【第四章-react ajax】
前端·react.js
前端若水30 分钟前
层叠层(@layer):彻底解决优先级战争,告别 !important
前端·css·css3
invicinble36 分钟前
前端框架使用vue-cli( 第二层:工程配置层--vue语法系列)
前端·vue.js·前端框架
爱滑雪的码农37 分钟前
React+three.js之场景(Scene),相机(Camera)
前端·javascript·react.js
UXbot39 分钟前
AI应用原型平台核心能力:界面自动生成、交互流程编辑、多格式代码导出详解
前端·低代码·交互·软件构建·原型模式·web app
call me by ur name41 分钟前
多模态大模型轻量化
前端·网络·人工智能
Lee川44 分钟前
登录注册模块的 JWT 认证机制详解
前端·后端·react.js