当前位置:首页 > JavaScript

js 实现截图

2026-01-16 12:58:49JavaScript

使用html2canvas库实现截图

html2canvas是一个流行的JavaScript库,可将HTML元素转换为Canvas,进而导出为图片。

安装库:

npm install html2canvas

基础代码示例:

import html2canvas from 'html2canvas';

const element = document.getElementById('target-element');
html2canvas(element).then(canvas => {
  const imgData = canvas.toDataURL('image/png');
  const link = document.createElement('a');
  link.download = 'screenshot.png';
  link.href = imgData;
  link.click();
});

使用Canvas的toDataURL方法

若需截取Canvas自身内容,可直接使用其原生API:

const canvas = document.getElementById('myCanvas');
const dataURL = canvas.toDataURL('image/jpeg', 0.8); // 80%质量
console.log(dataURL); // 输出Base64编码

浏览器原生API:MediaDevices.getDisplayMedia

适用于截取屏幕、窗口或标签页内容:

async function captureScreen() {
  const stream = await navigator.mediaDevices.getDisplayMedia({ video: true });
  const videoTrack = stream.getVideoTracks()[0];
  const imageCapture = new ImageCapture(videoTrack);
  const bitmap = await imageCapture.grabFrame();

  const canvas = document.createElement('canvas');
  canvas.width = bitmap.width;
  canvas.height = bitmap.height;
  const ctx = canvas.getContext('2d');
  ctx.drawImage(bitmap, 0, 0);
  videoTrack.stop();

  // 导出图片
  canvas.toBlob(blob => {
    const url = URL.createObjectURL(blob);
    const a = document.createElement('a');
    a.href = url;
    a.download = 'screen-capture.png';
    a.click();
  }, 'image/png');
}

注意事项

  • 跨域限制:若截图内容包含跨域图片,需确保图片服务器允许CORS。
  • 性能优化:对大范围DOM截图时,html2canvas可能较慢,建议限制截图区域。
  • 样式兼容性:某些CSS属性(如filter、transform)可能导致渲染差异。

扩展方案:第三方服务

若需云端截图,可考虑:

js 实现截图

  • Puppeteer:通过Headless Chrome生成截图,适用于Node.js环境。
  • APIfox:提供网页截图API,直接通过HTTP请求调用。

以上方法覆盖了从前端DOM到屏幕的常见截图场景,可根据具体需求选择。

标签: 截图js
分享给朋友:

相关文章

js实现选项卡

js实现选项卡

实现选项卡的基本思路 选项卡通常由一组标签和对应的内容面板组成。点击标签时,显示对应的内容面板,隐藏其他面板。实现这一效果需要结合HTML结构、CSS样式和JavaScript交互逻辑。 HTML结…

js实现百叶窗

js实现百叶窗

使用CSS和JavaScript实现百叶窗效果 通过CSS动画和JavaScript事件监听可以实现百叶窗效果。核心思路是将内容区域分割为多个条状元素,通过控制它们的展开/折叠状态来模拟百叶窗。 &…

js实现自举

js实现自举

实现 JavaScript 自举的方法 JavaScript 自举(Bootstrap)通常指通过 JavaScript 动态加载自身或依赖的脚本,实现运行时环境的初始化或扩展。以下是几种常见实现方式…

vue实现js休眠

vue实现js休眠

实现 JavaScript 休眠的方法 在 Vue 中实现 JavaScript 休眠(延迟执行)可以通过以下方式实现。由于 JavaScript 本身没有内置的 sleep 函数,通常使用 Prom…

js实现轮播代码

js实现轮播代码

基础轮播实现 使用HTML、CSS和JavaScript创建一个简单的轮播效果。HTML部分定义轮播容器和图片元素。 <div class="carousel"> <div c…

H5手机端实现长截图

H5手机端实现长截图

实现H5手机端长截图的方法 使用html2canvas库 html2canvas是一个流行的JavaScript库,可以将网页内容渲染为Canvas图像。通过遍历页面所有元素,将其绘制到Canvas上…