vue3图片下载

复制代码
const handleDownload = () => {
  const imgUrl1 ="https://cube.elemecdn.com/6/94/4d3ea53c084bad6931a56d5158a48jpeg.jpeg";
  fetch(imgUrl1)
    .then(response => response.blob())
    .then(blob => {
      // 创建一个Blob URL
      const url = URL.createObjectURL(blob);

      // 创建一个a标签用于下载
      const a = document.createElement('a');
      a.style.display = 'none';
      a.href = url;
      // 设置下载的文件名,这里假设是"avatar.jpeg"
      a.download =  `证书.png`;
      document.body.appendChild(a);
      a.click();

      // 释放Blob URL
      URL.revokeObjectURL(url);

      // 清理a标签
      document.body.removeChild(a);
    })
    .catch(error => console.error('下载失败:', error));
  // const base64String = "data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQABAAD..."; // 示例Base64字符串
  //
  // // 提取Base64编码部分
  // const byteString = atob(base64String.split(',')[1]);
  //
  // // 创建一个Blob对象
  // const ab = new ArrayBuffer(byteString.length);
  // const ia = new Uint8Array(ab);
  // for (let i = 0; i < byteString.length; i++) {
  //   ia[i] = byteString.charCodeAt(i);
  // }
  //
  // const blob = new Blob([ab], { type: 'image/jpeg' });
  //
  // // 创建一个a标签用于下载
  // const a = document.createElement('a');
  // a.style.display = 'none';
  // a.href = URL.createObjectURL(blob);
  // a.download = 'image.jpeg'; // 设置下载的文件名
  // document.body.appendChild(a);
  // a.click();
  //
  // // 释放Blob URL
  // URL.revokeObjectURL(a.href);
  //
  // // 清理a标签
  // document.body.removeChild(a);

}
相关推荐
万物得其道者成5 小时前
前端大整数精度丢失:一次踩坑后的实战解决方案(`json-bigint`)
前端·json
鹏北海5 小时前
移动端 H5 响应式字体适配方案完全指南
前端
姜太公钓鲸2336 小时前
ROM就是程序存储器,实际的存储介质是Flash闪存。上述描述中的程序存储器是什么意思?
开发语言·javascript·ecmascript
Java后端的Ai之路6 小时前
【JDK】-JDK 21 新特性内容
java·开发语言·后端·jdk·jdk21
wjs20246 小时前
JavaScript 作用域
开发语言
柳杉7 小时前
使用AI从零打造炫酷医疗数据可视化大屏,源码免费拿!
前端·javascript·数据可视化
m0_531237177 小时前
C语言-指针终阶
c语言·开发语言
凌云拓界7 小时前
前端开发的“平衡木”:在取舍之间找到最优解
前端·性能优化·架构·前端框架·代码规范·设计规范
散峰而望7 小时前
C++ 启程:从历史到实战,揭开命名空间的神秘面纱
c语言·开发语言·数据结构·c++·算法·github·visual studio
zhengfei6117 小时前
【XSS payload 】一个经典的XSS payload
前端·xss