Blob与File、DataURL、canvas的相互转换

2021-11-13  本文已影响0人  天問_专注于大前端技术

因为浏览器沙箱的存在,web端操作文件的限制比较多,只能进行一些简单的文件上传下载。对于编辑文件和文件转换感到苍白无力,但这并不代表说毫无办法。随着现代化浏览器的不断升级,也提供了一些好用强大的API可以间接操作文件,例如文本中的Blobcanvas等等。

Javascript Blob

一、概念介绍

二、相互转化

2-1. dataURL(base64) 转化成 Blob(二进制)对象

function dataURLToBlob(fileDataURL) {
    let arr = fileDataURL.split(','),
        mime = arr[0].match(/:(.*?);/)[1],
        bstr = atob(arr[1]),
        n = bstr.length,
        u8arr = new Uint8Array(n);
    while(n --) {
      u8arr[n] = bstr.charCodeAt(n)
    }
    return new Blob([u8arr], {type: mime})
}

2-2. FileBlob 文件数据绘制到 canvas

// 思路:File, Blob ——> dataURL ——> canvas

function fileAndBlobToCanvas(fileDataURL) {
    let img = new Image()
    img.src = fileDataURL
    let canvas = document.createElement('canvas')
    if(!canvas.getContext) {
      alert('浏览器不支持canvas')
      return;
    }
    let ctx = canvas.getContext('2d')
    document.getElementById('container').appendChild(canvas)
    img.onload = function() {
      ctx.drawImage(img, 0, 0, canvas.width, canvas.height)
    }
}

2-3. FileBlob 转化成 dataURL

FileReader: 对象允许 Web 应用程序异步读取文件(或原始数据缓冲区)内容,使用 FileBlob 对象指定要读取的文件或数据。

function fileToDataURL(file) {
    let reader = new FileReader()
    reader.readAsDataURL(file)
    // reader 读取文件成功的回调
    reader.onload = function(e) {
      return reader.result
    }
}

2-4. 从 canvas 中获取文件 dataURL

function canvasToDataURL() {
    let canvas = document.createElement('canvas')
    let canvasDataURL = canvas.toDataURL('image/png', 1.0)
    return canvasDataURL
}

欢迎访问:天问博客

上一篇下一篇

猜你喜欢

热点阅读