前端图片canvas,file,blob,DataURL等格式转换
将file转化成blob
- 利用URL.createObjectURL()
let $img = document.getElementById('img')
file.onchange = function (e) {
let file = e.target.files[0]
let fileUrl = window.URL.createObjectURL(file)
$img.src = fileUrl
img.onload = function () {
// 手动回收
URL.revokeObjectURL(fileUrl)
}
}
当选择图片后,生成的img src类似"blob:null/4304d4f3-c13b-43e8-83f6-8c80426520ff",能正常显示图片。
将file转化为DataURL
- 利用FileReader.readAsDataURL()
let $img = document.getElementById('img')
file.onchange = function (e) {
console.log(e.target.files)
let file = e.target.files[0]
const fr = new FileReader(file)
fr.readAsDataURL(file)
fr.onload = function () {
$img.src = this.result
}
}
canvas转为DataURL
canvas画出来的图片,在html中的其他地方显示。这里的方法也是可以将canvas输出为Dataurl的来放到img标签中。
let imgSrc = canvas.toDataURL('image/png')
// canvas.toDataURL('image/jpeg')
canvas转为blob对象
将canvas输出为Blob对象,这样就可以像File对象一样操作它了
canvas.toBlob(function (blobObj) {
console.log(blobObj) //blobObj就是blob对象(类文件)
})
Blob对象显示图片
同上,如果拿到blob对象,亦可以使用
URL.createObjectURL()
来进行转换
canvas.toBlob(function (blobObj) {
console.log(blobObj) //blobObj就是blob对象(类文件)
let imgSrc = window.URL.createObjectURL(blobObj)
document.getElementById('img').src = imgSrc
})
最后附一个下载DataURL下载方法:
function downloadImg () {
let aLink = document.createElement('a')
aLink.download = 'fileName.png' // 文件名后缀需要和dataurl表示的相同,否则可能乱码
aLink.href = dataUrl
aLink.click()
}