Vue 实现:点击按钮将 HTML 导出为图片(完整教程)

在日常开发中,经常会遇到这样的需求:

将页面内容生成图片(分享海报)

导出报表截图

本文将教你如何在 Vue 项目中,一键将 HTML 内容导出为图片(PNG)

一、实现原理

我们借助一个非常常用的库:

html2canvas

它的核心作用是:

DOM → Canvas → Base64 → 图片下载

简单来说,就是把页面"截图"下来。


二、安装依赖

npm install html2canvas


三、基础实现(完整代码)

1 页面结构

html 复制代码
<div id="capture">
 <h2>这是要导出的内容</h2>
 <p>Vue 导出 HTML 为图片示例</p>
</div>

<button @click="downloadImage">下载图片</button>

2 JS 实现

javascript 复制代码
import html2canvas from "html2canvas"

export default {
  methods: {
    downloadImage() {
      const dom = document.getElementById("capture")

      html2canvas(dom, {
        scale: 2, // 提高清晰度
        useCORS: true
      }).then(canvas => {
        const imgData = canvas.toDataURL("image/png")

        const link = document.createElement("a")
        link.href = imgData
        link.download = "vue截图.png"
        link.click()
      })
    }
  }
}

四、推荐写法(Vue 更优雅)

使用 ref 获取 DOM:

javascript 复制代码
downloadImage() {
  html2canvas(this.$refs.capture, {
    scale: 2
  }).then(canvas => {
    const link = document.createElement("a")
    link.download = "test.png"
    link.href = canvas.toDataURL()
    link.click()
  })
}

五、效果流程

点击按钮

获取 DOM

html2canvas 渲染

生成 canvas

转 base64

下载图片


六、常见问题 & 解决方案

1. 图片模糊

原因:分辨率低

解决:

html2canvas(dom, {

scale: 2 // 或 window.devicePixelRatio

})


2. 图片加载不出来(跨域)

javascript 复制代码
html2canvas(dom, {
  useCORS: true
})

同时图片服务器需要支持:

Access-Control-Allow-Origin


3. 字体丢失

复制代码
document.fonts.ready.then(() => {
  downloadImage()
})

总结

核心步骤只有 4 步:

  1. 获取 DOM

  2. html2canvas 渲染

  3. canvas 转图片

  4. 触发下载

相关推荐
shao9185168 小时前
第3章(2)——使用Gradio JavaScript Client
javascript·node.js·cdn·gradio·job·events·playcode
光影少年8 小时前
大屏页面,一次多个请求,请求加密导致 点击 全局时间选择器 时出现卡顿咋解决(面板收起会延迟1~2秒)
前端·javascript·vue.js·学习·前端框架·echarts·reactjs
Mr.mjw8 小时前
vue中封装一个环形进度条组件,根据外部盒子大小自适应变化
前端·javascript·vue.js
无心使然8 小时前
Openlayers调用ArcGis影像服务之一动态地图、地图切片(/exportImage)
前端·javascript·数据可视化
唯火锅不可辜负8 小时前
uniapp开发公众号订阅功能踩坑小记
前端·vue.js
像我这样帅的人丶你还8 小时前
前端监控体系与实践(二):全局监控
前端·javascript·vue.js
前端那点事9 小时前
Vue3 超全复盘!30+前端高频核心知识点(开发+面试全覆盖)
前端·vue.js
顾随9 小时前
(二)kettle--输入与输出
javascript·数据库·kettle
FlyWIHTSKY9 小时前
Vue 3 中 RouteRecord 详解(Vue Router 4)
前端·javascript·vue.js
老王以为9 小时前
前端视角下的 Java
java·javascript·程序员