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

}
相关推荐
FIN66681 小时前
昂瑞微:实现精准突破,攻坚射频“卡脖子”难题
前端·人工智能·安全·前端框架·信息与通信
椎4951 小时前
苍穹外卖前端nginx错误之一解决
运维·前端·nginx
@。1241 小时前
对于灰度发布(金丝雀发布)的了解
开发语言·前端
我有一棵树1 小时前
前端图片加载失败、 img 出现裂图的原因全解析
前端
FIN66681 小时前
昂瑞微冲刺科创板:硬科技与资本市场的双向奔赴
前端·人工智能·科技·前端框架·智能
im_AMBER1 小时前
杂记 14
前端·笔记·学习·web
牧杉-惊蛰1 小时前
disable-devtool 网络安全 禁止打开控制台
前端·css·vue.js
C+ 安口木2 小时前
vue中监听window某个属性被添加或值的变化
前端·javascript·vue.js
山海鲸可视化2 小时前
简单聊聊数据可视化大屏制作的前端设计与后端开发
前端·信息可视化·数字孪生·数据可视化·3d模型·三维渲染
CoderYanger2 小时前
前端基础-HTML入门保姆级课堂笔记
前端·javascript·css·html