vue3 下载图片(标签内容可转图)

这种方法可以用来捕获页面上的任意元素并将其转换为图片格式进行下载,适合于生成包含特定内容的图片(如海报、证书等)。

安装插件 npm install html2canvas

复制代码
<template>
  <div>
    <div ref="contentRef" style="padding: 20px; border: 1px solid #ccc;">
      <h1>Hello Vue 3</h1>
      <p>这是一段要下载为图片的内容。</p>
      <!-- 如果包含跨域图片 -->
      <img src="https://example.com/cross-origin-image.jpg" alt="Cross Origin Image">
    </div>
    <button @click="downloadAsImage">下载为图片</button>
  </div>
</template>

<script setup>
import { ref, nextTick } from 'vue';
import html2canvas from 'html2canvas';

const contentRef = ref(null);

const downloadAsImage = async () => {
  await nextTick(); // 确保 DOM 更新完成

  const element = contentRef.value;
  if (!element) {
    console.error('元素未找到');
    return;
  }

  try {
    const canvas = await html2canvas(element, {
      useCORS: true // 启用跨域支持
    });

    const link = document.createElement('a');
    link.href = canvas.toDataURL('image/png');
    link.download = 'content.png';
    link.click();
  } catch (error) {
    console.error('截图失败:', error);
  }
};
</script>
相关推荐
dlhto12 分钟前
前端登录验证码组件
前端
@万里挑一14 分钟前
vue中使用虚拟列表,封装虚拟列表
前端·javascript·vue.js
黑臂麒麟18 分钟前
Electron for OpenHarmony 跨平台实战开发:Electron 文件系统操作实战
前端·javascript·electron·openharmony
wordbaby18 分钟前
Tanstack Router 文件命名速查表
前端
1024肥宅25 分钟前
工程化工具类:模块化系统全解析与实践
前端·javascript·面试
软件技术NINI26 分钟前
如何学习前端
前端·学习
weixin_4225554227 分钟前
ezuikit-js官网使用示例
前端·javascript·vue·ezuikit-js
梓仁沐白37 分钟前
CSAPP-Attacklab
前端
郑州光合科技余经理1 小时前
海外国际版同城服务系统开发:PHP技术栈
java·大数据·开发语言·前端·人工智能·架构·php
zhz52141 小时前
代码之恋(第十五篇:分布式心跳与网络延迟)
网络·分布式·ai·重构·vue·结对编程