推广 热搜: csgo  vue  angelababy  2023  gps  新车  htc  落地  app  p2p 

Base64、Blob、File 三种类型的相互转换 最详细

   2023-07-17 网络整理佚名1710
核心提示:摘要、blob、file字符串的格式表示出来。数据传输编码。对象表示一个不可变、原始数据的类文件对象。表示的不一定是原生格式的数据。的功能并将其扩展使其支持用户系统上的文件。访问其内容。在Gecko中,特权代码可以创建代表任何本地文件的File对象,而无需用户交互(有关详细信息,请参阅注意事项。中。主要应用场景:图片预览主要应用场景:文件上传主要应用场景:文件上传主要应用场景:文件上传主要应用场景:文件上传主要应用场景:图片预览

概括

我是一名兼职开发人员。 有需要的可以加我微信。 评论

、斑点、文件

、Blob、文件 API

它是一组类似二进制到文本(-)的编码规则,使得二进制数据在被解释为radix-64表示后可以以ASCII字符串格式表示。 该词来自 MIME 数据传输编码。

斑点

Blob 对象表示不可变的原始数据的类文件对象。 Blob 不一定以其本机格式表示数据。 File接口基于Blob,继承了blob的功能,并扩展了它以支持用户系统上的文件。

文件

文件接口提供有关文件的信息并允许网页访问其内容。

通常情况下,File 对象是用户在元素上选择文件后返回的对象,也可以是通过拖放操作生成的对象,也可以是通过上述() API 生成的对象。 在 Gecko 中,特权代码可以创建代表任何本地文件的 File 对象,而无需用户交互(有关详细信息,请参阅注释。

文件对象是一种特殊类型的 Blob,可以与任何 Blob 类型一起使用。 例如,URL.()、() 和 .send() 都适用于 Blob 和文件。

、Blob、File三种类型的相互转换1、文件转换

主要应用场景:图像预览


<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>documenttitle>
    <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js">script>
head>
<body>
    <input type="file" name="file" id="file" multiple>br>
    <button id="fileTobase">File 转 base64button><br>
    <img id="img" src="" alt="">
    <script>
        // 文件类型转base64
        const fileTobase64 = (file, callback) => {
            const reader = new FileReader();
            reader.onload = function(evt) {
                if(typeof callback === 'function') {
                    callback(evt.target.result)
                } else {
                    console.log("我是base64:", evt.target.result);
                }
            };
            reader.readAsDataURL(file);
        };
        $("#fileTobase").click(function (e) { 
            e.preventDefault();
            // 获取文件对象
            const _file = $("#file")[0].files[0];
            const base64 = fileTobase64(_file, base64 => {
                console.log('我是base64:', base64);
                // 预览图片
                $("#img").attr({"src": base64})
            });
        });
    script>
body>
html>

2. 文件到 Blob

主要应用场景:文件上传


<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>File 转 Blobtitle>
    <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js">script>
head>
<body>
    <input type="file" name="file" id="file">br>
    <button id="fileToBlob">File 转 Blobbutton><br>
    <script>
        // 文件类型转Blob
        const fileToBlob = (file, callback) => {
            const type = file.type;
            const reader = new FileReader();
            reader.onload = function(evt) {
                const blob = new Blob([evt.target.result], {type});
                if(typeof callback === 'function') {
                    callback(blob)
                } else {
                    console.log("我是 blob:", blob);
                }
            };
            reader.readAsDataURL(file);
        };
        $("#fileToBlob").click(function (e) { 
            e.preventDefault();
            // 获取文件对象
            const _file = $("#file")[0].files[0];
            fileToBlob(_file, blob => {
                console.log('我是 blob:', blob);
            });
        });
    script>
body>
html>

3. 传输到文件

主要应用场景:文件上传


<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>base64 转 Filetitle>
    <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js">script>
head>
<body>
    <img id="img" src="" alt="" srcset="">
    <br>
    <input style="display: none;" type="text" name="base64" id="base64" value="">
    <br>
    <button id="base64ToFile">base64 转 Filebutton><br>
    <script>
        $("#img").attr({'src': $("#base64").val()})
        // base64 转 File
        const base64ToFile = (base64, fileName) => {
            let arr = base64.split(','), type = arr[0].match(/:(.*?);/)[1], bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
            while(n--){
                u8arr[n] = bstr.charCodeAt(n);
            }
            return new File([u8arr], fileName, {type});
        };
        $("#base64ToFile").click(function (e) { 
            e.preventDefault();
            // 获取base64
            const base64 = $("#base64").val();
            console.log("我是 base64:", base64);
            const file = base64ToFile(base64, 'fileName');
            console.log("我是 file:", file);
        });
    script>
body>
html>

4. 转移到Blob

主要应用场景:文件上传


<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>base64 转 Blobtitle>
    <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js">script>
head>
<body>
    <img id="img" src="" alt="" srcset="">
    <br>
    <input style="display: none;" type="text" name="base64" id="base64" value="">
    <br>
    <button id="base64ToBlob">base64 转 Blobbutton><br>
    <script>
        $("#img").attr({'src': $("#base64").val()})
        // base64 转 Blob
        const base64ToBlob = base64 => {
            let arr = base64.split(','), type = 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});
        };
        $("#base64ToBlob").click(function (e) { 
            e.preventDefault();
            // 获取base64
            const base64 = $("#base64").val();
            console.log("我是 base64:", base64);
            const blob = base64ToBlob(base64);
            console.log("我是 Blob:", blob);
        });
    script>
body>
html>

5. Blob 到文件

主要应用场景:文件上传


<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Blob 转 Filetitle>
    <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js">script>
head>
<body>
    <input type="file" name="file" id="file">br>
    <button id="fileToBlob">Blob 转 Filebutton><br>
    <script>
        // 文件类型转Blob
        const fileToBlob = (file, callback) => {
            const type = file.type;
            const reader = new FileReader();
            reader.onload = function(evt) {
                const blob = new Blob([evt.target.result], {type});
                if(typeof callback === 'function') {
                    callback(blob)
                } else {
                    console.log("我是 blob:", blob);
                }
            };
            reader.readAsDataURL(file);
        };
        // Blob 转 File
        const blobToFile = (blob, fileName) => {
            const file = new File([blob], fileName, {type: blob.type});
            return file;
        }
        $("#fileToBlob").click(function (e) { 
            e.preventDefault();
            // 获取文件对象
            const _file = $("#file")[0].files[0];
            fileToBlob(_file, blob => {
                console.log('我是 blob:', blob);
                const file = blobToFile(blob, 'fileName');
                console.log('我是 file', file);
            });
        });
    script>
body>
html>

6. Blob 传输

主要应用场景:图像预览


<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Blob 转 base64title>
    <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js">script>
head>
<body>
    <input type="file" name="file" id="file">br>
    <button id="blobTobase64">Blob 转 base64button><br>
    <script>
        // 文件类型转Blob
        const fileToBlob = (file, callback) => {
            const type = file.type;
            const reader = new FileReader();
            reader.onload = function(evt) {
                const blob = new Blob([evt.target.result], {type});
                if(typeof callback === 'function') {
                    callback(blob)
                } else {
                    console.log("我是 blob:", blob);
                }
            };
            reader.readAsDataURL(file);
        };
        // Blob 转 base64
        const blobTobase64 = (blob, callback) => {
            let r = new FileReader();
            r.onload = function (e) {
                if (typeof callback === 'function') {
                    callback(e.target.result);
                } else {
                    console.log("我是 base64: ", e.target.result);
                }
            }
            r.readAsDataURL(blob);
        }
        $("#blobTobase64").click(function (e) { 
            e.preventDefault();
            // 获取文件对象
            const _file = $("#file")[0].files[0];
            fileToBlob(_file, blob => {
                console.log('我是 blob:', blob);
                blobTobase64(blob, base64 => {
                    console.log("我是 base64: ", base64);
                });
            });
        });
    script>
body>
html>

 
反对 0举报 0 收藏 0 打赏 0评论 0
 
更多>同类资讯
推荐图文
推荐资讯
点击排行
网站首页  |  关于我们  |  联系方式  |  使用协议  |  版权隐私  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  网站留言  |  RSS订阅  |  违规举报
Powered By DESTOON