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>
相关推荐
腾蛇月猫1 分钟前
Excel转VCF文件一键导入通讯录联系人信息
javascript·excel·vcf
EndingCoder2 分钟前
Node.js 数据查询优化技巧
服务器·javascript·数据库·node.js·数据查询优化
芒果Cake10 分钟前
【Node.js】Node.js 模块系统
javascript·node.js
極光未晚15 分钟前
乾坤微前端项目:前端处理后台分批次返回的 Markdown 流式数据
前端·vue.js·面试
用户842981424181015 分钟前
Auto.js脚本加密
javascript
用户66006766853916 分钟前
用 CSS3 导演一场星际穿越:复刻“星球大战”经典片头
前端·css
程序员鱼皮16 分钟前
前后端分离,千万别再搞错了!
java·前端·后端·计算机·程序员·编程·软件开发
前端赵哈哈17 分钟前
Vite 构建后产品详情页图片失效?从路径匹配到映射表的完美解决
前端·vue.js·vite
葡萄城技术团队17 分钟前
React Native 错误处理完全指南
前端
苏打水com18 分钟前
深入浅出 JavaScript 异步编程:从回调地狱到 Async/Await
开发语言·javascript·ecmascript