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>
相关推荐
ObjectX前端实验室1 小时前
【react18原理探究实践】scheduler原理之Task 完整生命周期解析
前端·react.js
ObjectX前端实验室1 小时前
【react18原理探究实践】调度器(Scheduler)原理深度解析
前端·react.js
路漫漫心远1 小时前
音视频学习笔记十八——图像处理之OpenCV检测
前端
摸着石头过河的石头1 小时前
从零开始玩转前端:一站式掌握Web开发基础知识
前端·javascript
sniper_fandc2 小时前
关于Mybatis-Plus的insertOrUpdate()方法使用时的问题与解决—数值精度转化问题
java·前端·数据库·mybatisplus·主键id
10岁的博客2 小时前
技术博客SEO优化全攻略
前端
南屿im3 小时前
别再被引用坑了!JavaScript 深浅拷贝全攻略
前端·javascript
想要一辆洒水车3 小时前
vuex4源码分析学习
前端
sophie旭3 小时前
一道面试题,开始性能优化之旅(6)-- 异步任务和性能
前端·javascript·性能优化
年少不知有林皇错把梅罗当球王3 小时前
vue2、vue3中使用pb(Base64编码)
前端