base64图片转url格式

1,220 阅读1分钟
//将图片转为文件
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)