文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何在HTML5中使用Blob对象

2023-06-09 10:49

关注

这篇文章将为大家详细讲解有关如何在HTML5中使用Blob对象,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

html有什么特点

1、简易性:超级文本标记语言版本升级采用超集方式,从而更加灵活方便,适合初学前端开发者使用。2、可扩展性:超级文本标记语言的广泛应用带来了加强功能,增加标识符等要求,超级文本标记语言采取子类元素的方式,为系统扩展带来保证。 3、平台无关性:超级文本标记语言能够在广泛的平台上使用,这也是万维网盛行的一个原因。4、通用性:HTML是网络的通用语言,它允许网页制作人建立文本与图片相结合的复杂页面,这些页面可以被网上任何其他人浏览到,无论使用的是什么类型的电脑或浏览器。

Blob对象

一直以来,JS都没有比较好的可以直接处理二进制的方法。而Blob的存在,允许我们可以通过JS直接操作二进制数据。

一个Blob对象就是一个包含有只读原始数据的类文件对象。Blob对象中的数据并不一定得是JavaScript中的原生形式。File接口基于Blob,继承了Blob的功能,并且扩展支持了用户计算机上的本地文件。

Blob对象可以看做是存放二进制数据的容器,此外还可以通过Blob设置二进制数据的MIME类型。

创建Blob

通过构造函数

var blob = new Blob(dataArr:Array<any>, opt:{type:string});

dataArray:数组,包含了要添加到Blob对象中的数据,数据可以是任意多个ArrayBuffer,ArrayBufferView, Blob,或者 DOMString对象。

opt:对象,用于设置Blob对象的属性(如:MIME类型)

创建一个装填DOMString对象的Blob对象

如何在HTML5中使用Blob对象

创建一个装填ArrayBuffer对象的Blob对象

如何在HTML5中使用Blob对象

创建一个装填ArrayBufferView对象的Blob对象(ArrayBufferView可基于ArrayBuffer创建,返回值是一个类数组。如下:创建一个8字节的ArrayBuffer,在其上创建一个每个数组元素为2字节的“视图”)

如何在HTML5中使用Blob对象

通过Blob.slice()

此方法返回一个新的Blob对象,包含了原Blob对象中指定范围内的数据

Blob.slice(start:number, end:number, contentType:string)

start:开始索引,默认为0
end:截取结束索引(不包括end)
contentType:新Blob的MIME类型,默认为空字符串

如何在HTML5中使用Blob对象

var canvas = document.getElementById("canvas");canvas.toBlob(function(blob){    console.log(blob);});

如何在HTML5中使用Blob对象

应用场景

前面提到,File接口基于Blob,继承了Blob的功能并进行了扩展,故我们可以像使用Blob一样使用File对象。

分片上传

通过Blob.slice方法,可以将大文件分片,轮循向后台提交各文件片段,即可实现文件的分片上传。
分片上传逻辑如下:

下面是分片上传的简单实现:

initUpload();//初始化上传function initUpload() {    var chunk = 100 * 1024;   //每片大小    var input = document.getElementById("file");    //input file    input.onchange = function (e) {        var file = this.files[0];        var query = {};        var chunks = [];        if (!!file) {            var start = 0;            //文件分片            for (var i = 0; i < Math.ceil(file.size / chunk); i++) {                var end = start + chunk;                chunks[i] = file.slice(start , end);                start = end;            }                        // 采用post方法上传文件            // url query上拼接以下参数,用于记录上传偏移            // post body中存放本次要上传的二进制数据            query = {                fileSize: file.size,                dataSize: chunk,                nextOffset: 0            }            upload(chunks, query, successPerUpload);        }    }}// 执行上传function upload(chunks, query, cb) {    var queryStr = Object.getOwnPropertyNames(query).map(key => {        return key + "=" + query[key];    }).join("&");    var xhr = new XMLHttpRequest();    xhr.open("POST", "http://xxxx/opload?" + queryStr);    xhr.overrideMimeType("application/octet-stream");        //获取post body中二进制数据    var index = Math.floor(query.nextOffset / query.dataSize);    getFileBinary(chunks[index], function (binary) {        if (xhr.sendAsBinary) {            xhr.sendAsBinary(binary);        } else {            xhr.send(binary);        }    });    xhr.onreadystatechange = function (e) {        if (xhr.readyState === 4) {            if (xhr.status === 200) {                var resp = JSON.parse(xhr.responseText);                // 接口返回nextoffset                // resp = {                //     isFinish:false,                //     offset:100*1024                // }                if (typeof cb === "function") {                    cb.call(this, resp, chunks, query)                }            }        }    }}// 每片上传成功后执行function successPerUpload(resp, chunks, query) {    if (resp.isFinish === true) {        alert("上传成功");    } else {        //未上传完毕        query.offset = resp.offset;        upload(chunks, query, successPerUpload);    }}// 获取文件二进制数据function getFileBinary(file, cb) {    var reader = new FileReader();    reader.readAsArrayBuffer(file);    reader.onload = function (e) {        if (typeof cb === "function") {            cb.call(this, this.result);        }    }}

以上是文件分片上传前端的简单实现,当然,此功能还可以更加完善,如后台需要对合并后的文件大小进行校验;或者前端加密文件,全部上传完毕后后端解密校验等,此处不做赘述。

通过url下载文件

window.URL对象可以为Blob对象生成一个网络地址,结合a标签的download属性,可以实现点击url下载文件
实现如下:

createDownload("download.txt","download file");function createDownload(fileName, content){    var blob = new Blob([content]);    var link = document.createElement("a");    link.innerHTML = fileName;    link.download = fileName;    link.href = URL.createObjectURL(blob);    document.getElementsByTagName("body")[0].appendChild(link);}

执行后页面上会生成此Blob对象的地址,点击后可下载:

如何在HTML5中使用Blob对象

查看下载结果:

如何在HTML5中使用Blob对象

通过url显示图片

我们知道,img的src属性及background的url属性,都可以通过接收图片的网络地址或base64来显示图片,同样的,我们也可以把图片转化为Blob对象,生成URL(URL.createObjectURL(blob)),来显示图片。

如何在HTML5中使用Blob对象

关于如何在HTML5中使用Blob对象就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯