//将图片转为文件
function base64ImgToFile (dataurl, filename = 'file') {
//将base64格式分割:['data:image/png;base64','XXXX']
const arr = dataurl.split(',')
// .*? 表示匹配任意字符到下一个符合条件的字符 刚好匹配到:
// image/png
const mime = arr[0].match(/:(.*?);/)[1] //image/png
//[image,png] 获取图片类型后缀
const suffix = mime.split('/')[1] //png
const bstr = atob(arr[1]) //atob() 方法用于解码使用 base-64 编码的字符串
let n = bstr.length
const u8arr = new Uint8Array(n)
while (n--) {
u8arr[n] = bstr.charCodeAt(n)
}
return new File([u8arr], `${filename}.${suffix}`, {
type: mime
})
}
//将图片文件转为二进制,然后通过URL的createObjectURL函数,将二进制转为url格式
function getBase64URL(pic) {
const blob = base64ImgToFile(pic)
const blobUrl = window.URL.createObjectURL(blob);
return blobUrl
}
如vant的van-uploader拿到的fileList数组,将fileList的每一项进行处理
this.fileList.forEach((item, ind) => {
let fileLink = this.getBase64URL(item.content);
//fileLink打印出的格式为blob:http...截取一下
let fileStr = fileLink.slice(5, -1);
this.urlList.push(fileStr);
});
//拿到需要的url链接数组
console.log(this.urlList)