JavaScript 截取 HTML 生成图片

什么是 html2canvas

html2canvas 是一个强大的 JavaScript 库,它可以将 HTML 元素渲染成画布(Canvas),然后将其转换为图像。这个库支持大多数现代浏览器,并且易于使用。

安装 html2canvas

使用 npm 进行安装

js 复制代码
npm install html2canvas

也可以通过 CDN 引入

js 复制代码
<script src="https://cdn.bootcdn.net/ajax/libs/html2canvas/1.4.1/html2canvas.min.js"></script>

基本用法

js 复制代码
<template>
  <div class="html2Img_wrapper" ref="containerRef">
    <img src="/src/assets/img.jpg" width="300" />
    <h3>ryutyrurt</h3>
    <button @click="handleHtml2Img">转换为图片</button>
  </div>
</template>
<script setup>
import { ref, nextTick } from "vue";
const containerRef = ref();

const handleHtml2Img = () => {
  html2canvas(containerRef.value, {
    scale: 2,
    useCORS: true,
    logging: true,
  })
    .then((canvas) => {
      // 方法一:转为base64;
      const img = canvas.toDataURL("image/png");
      const imgElement = document.createElement("img");
      imgElement.src = img;
      document.body.appendChild(imgElement);
      
      // 方法二:生成blob;
      canvas.toBlob((blob) => {
        const url = URL.createObjectURL(blob);
        const a = document.createElement("a");
        a.href = url;
        a.download = "页面截图.png";
        document.body.appendChild(a);
        a.click();
        setTimeout(() => {
          URL.revokeObjectURL(url);
          a.remove();
        }, 100);
        console.log(url);
      });
    })
    .catch((err) => {
      console.log("转换失败:", err);
    });
};
</script>

拓展

js如何见html转换成图片
前端实现HTML转图片并导出的完整方案
使用 JavaScript 截取 HTML 并生成图片:html2canvas

相关推荐
Qrun43 分钟前
Windows11安装nvm管理node多版本
前端·vscode·react.js·ajax·npm·html5
中国lanwp43 分钟前
全局 npm config 与多环境配置
前端·npm·node.js
JELEE.2 小时前
Django登录注册完整代码(图片、邮箱验证、加密)
前端·javascript·后端·python·django·bootstrap·jquery
TeleostNaCl4 小时前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
前端大卫5 小时前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友5 小时前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
小李小李不讲道理7 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻7 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
mapbar_front8 小时前
在职场生存中如何做个不好惹的人
前端
牧杉-惊蛰8 小时前
纯flex布局来写瀑布流
前端·javascript·css