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);

}
相关推荐
源代码•宸1 小时前
分布式缓存-GO(分布式算法之一致性哈希、缓存对外服务化)
开发语言·经验分享·分布式·后端·算法·缓存·golang
云和数据.ChenGuang1 小时前
PHP-FPM返回的File not found.”的本质
开发语言·php·运维工程师·运维技术
R.lin2 小时前
Java 8日期时间API完全指南
java·开发语言·python
哆啦A梦15882 小时前
商城后台管理系统 03 登录布局
javascript·vue.js·elementui
yangpipi-2 小时前
《C++并发编程实战》 第4章 并发操作的同步
开发语言·c++
火钳游侠2 小时前
java单行注释,多行注释,文档注释
java·开发语言
曼巴UE52 小时前
UE FString, FName ,FText 三者转换,再次学习,官方文档理解
服务器·前端·javascript
有趣的我3 小时前
C++ 多态介绍
开发语言·c++
selt7913 小时前
Redisson之RedissonLock源码完全解析
android·java·javascript
fie88893 小时前
波束赋形MATLAB代码实现
开发语言·matlab