cropper.js生成的base64位编码转为普通File格式

2020-06-13  本文已影响0人  辉夜真是太可爱啦

首先来看下cropper/js生成的base64编码


image.png

接下来使用转为file格式的方法之后,效果如下

//base64转为普通文件格式
base64toFile (dataurl, filename = 'file') {
  let arr = dataurl.split(',')
  let mime = arr[0].match(/:(.*?);/)[1]
  let suffix = mime.split('/')[1]
  let bstr = atob(arr[1])
  let n = bstr.length
  let u8arr = new Uint8Array(n)
  while (n--) {
    u8arr[n] = bstr.charCodeAt(n)
  }
  return new File([u8arr], `${filename}.${suffix}`, {
    type: mime
  })
},
image.png

接下来是转为blob格式的方法,效果如下

// dataUrl 转 blob
base64toBlob (dataurl) {
  /* eslint-disable */
  var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1];
  var bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
  while(n--){
    u8arr[n] = bstr.charCodeAt(n);
  }
  return new Blob([u8arr], {type:mime});
  /* eslint-enable */
},
blob格式

顺带提一下,blob格式用URL.createObjectURL(file.raw)即可生成一个本地的src绑定地址用来图片预览。

上一篇 下一篇

猜你喜欢

热点阅读