js显示byte[] 转 Base64 编码显示图片

背景

项目中经常会用到页面显示图片的功能,比如前端接收后台传输的数据是 byte[] 类型的数据,这时我们可以转成 Base64编码的图片再进行显示。

byte[] 转 Base64 编码

private arrayBufferToBase64(buffer) {
  let binary = "";
  const bytes = new Uint8Array(buffer);
  const len = bytes.byteLength;
  for (let i = 0; i < len; i++) {
    binary += String.fromCharCode(bytes[i]);
  }
  //window.btoa():将ascii字符串或二进制数据转换成一个base64编码过的字符串,该方法不能直接作用于Unicode字符串.
  return window.btoa(binary);
}
private getImage() {
    const image = [-199,80...50];//从后台接收的 byte[] 类型的图片
    let imageBase64;
    imageBase64 = arrayBufferToBase64(image);
    //把Data URI scheme的图片类型和图片拼接起来
	imageBase64 = "data:image/png;base64," + imageBase64;    
}
  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
js中的byte数组换为base64可以通过使用btoa函数来实现。btoa函数是JavaScript中的内置函数,用于将Unicode字符串换为base64编码。 要将byte数组换为base64,可以按照以下步骤进行操作: 1. 首先,将byte数组换为一个以逗号分隔的字符串。可以使用Array.prototype.join()方法将数组元素连接起来,并使用逗号作为分隔符。 2. 然后,将逗号分隔的字符串换为Unicode字符串。这可以通过使用String.fromCharCode()方法和split()函数来实现。split()函数将逗号分隔的字符串分割成一个字符数组,并使用String.fromCharCode()方法将每个字符换为Unicode字符串。 3. 最后,将Unicode字符串换为base64编码。可以使用btoa函数将Unicode字符串换为base64编码的字符串。 下面是一个示例代码: ```javascript function byteToBase64(byteArray) { // 将byte数组换为逗号分隔的字符串 var arrayString = byteArray.join(','); // 将逗号分隔的字符串换为Unicode字符串 var unicodeString = String.fromCharCode.apply(null, arrayString.split(',')); // 将Unicode字符串换为base64编码 var base64String = btoa(unicodeString); return base64String; } // 示例用法 var byteArray = [72, 101, 108, 108, 111]; // byte数组: [72, 101, 108, 108, 111] var base64String = byteToBase64(byteArray); console.log(base64String); // 输出: SGVsbG8= ``` 这样,就可以通过以上步骤将byte数组换为base64编码的字符串。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值