js/vue.js将base64字符串转图片

在Vue.js中,将Base64字符串转换为图片并上传通常涉及以下步骤:

  1. 将Base64字符串转换为Blob对象。
  2. 使用FormData对象将Blob对象包装起来。
  3. 将转换后的图片流上传到服务器,或者下载到本地。

关于如何将图片转为base64编码可以看我另外一篇文章

https://blog.csdn.net/qq_45947853/article/details/135406007

这里主要介绍转为图片后下载到本地的方法:

处理方法主要是 base64ToBlob 的函数,它接收两个参数:一个 base64 编码的字符串和一个 MIME 类型的字符串。

  1. 使用 window.atob 方法将 base64 编码的字符串解码为二进制字符串。
  2. 函数创建了一个空的数组 byteArrays,用于存储转换后的二进制数据。
  3. 函数使用一个循环,每次处理二进制字符串的一部分(长度为 sliceSize)。在每次循环中,函数首先使用 slice 方法获取二进制字符串的一部分,然后创建一个新的数组 byteNumbers,用于存储这部分字符串的每个字符的字符代码(使用 charCodeAt 方法获取)。
  4. 函数使用 Uint8Array 构造函数将 byteNumbers 数组转换为一个 8 位无符号整数数组,然后将这个数组添加到 byteArrays 数组中。
  5. 函数使用 Blob 构造函数将 byteArrays 数组转换为一个 Blob 对象,并设置其 MIME 类型为传入的 mime 参数。
<template>
    <el-button type="primary" size="default" @click="downloadImage">下载</el-button>
</template>

<script setup lang="ts">
import { ref } from 'vue'

// 这里是你的Base64编码的字符串
let imgUrl = ref('....')


const base64ToBlob = (base64: string, mime: string) => {
  mime = mime || '';
  let sliceSize = 1024;
  let byteChars = window.atob(base64);
  let byteArrays = [];

  for (let offset = 0, len = byteChars.length; offset < len; offset += sliceSize) {
    let slice = byteChars.slice(offset, offset + sliceSize);

    let byteNumbers = new Array(slice.length);
    for (let i = 0; i < slice.length; i++) {
      byteNumbers[i] = slice.charCodeAt(i);
    }
    let byteArray = new Uint8Array(byteNumbers);

    byteArrays.push(byteArray);
  }

  return new Blob(byteArrays, { type: mime });
}

const downloadImage = () => {
  let base64ImageContent = imgUrl.value.replace(/^data:image\/(png|jpg|jpeg);base64,/, "");
  let blob = base64ToBlob(base64ImageContent, 'image/png');
  let url = URL.createObjectURL(blob);
  let link = document.createElement('a');
  link.href = url;
  link.download = 'image.png';
  link.click();
}


</script>

  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值