JavaScript中Blob的具体实现
常用于处理文件数据、图像数据、音频数据等。Blob对象通常用于在客户端处理文件,如上传文件、下载文件、处理图像等操作。Blob对象可以通过Blob构造函数创建,也可以通过其他方式获取,比如从File对象中获取。
使用场景
- 文件上传:将用户选择的文件转换为Blob对象,然后通过Ajax请求将Blob对象发送到服务器。
- 文件下载:将服务器返回的文件数据转换为Blob对象,然后通过URL.createObjectURL()生成下载链接,供用户下载。
- 图片处理:将图片文件转换为Blob对象,然后可以进行压缩、裁剪等操作。
- 音频视频处理:处理音频、视频文件时,也可以使用Blob对象来操作二进制数据。
相关API
- slice(start, end, contentType):从Blob对象中提取指定范围的数据,返回一个新的Blob对象。参数start和end分别表示提取数据的起始和结束位置(单位为字节),contentType是可选的,表示新Blob对象的MIME类型。
const blob = new Blob(["Hello, world!"]); const slicedBlob = blob.slice(0, 5, "text/plain");
- size:返回Blob对象的大小,单位为字节。
const blob = new Blob(["Hello, world!"]); console.log(blob.size); // 输出 13
- type:返回Blob对象的MIME类型。
const blob = new Blob(["Hello, world!"], { type: "text/plain" }); console.log(blob.type); // 输出 "text/plain"
- arrayBuffer():将Blob对象转换为ArrayBuffer对象。
const blob = new Blob(["Hello, world!"]); blob.arrayBuffer().then(arrayBuffer => { // 处理ArrayBuffer对象 });
注意事项
如果不想再使用这个对象。可以调用URL.revokeObjectURL(你的url)
,最好在不使用时候就释放,减少占用资源
创建 Blob对象
var blob = new Blob(["Hello World!"],{type:"text/plain"}); console.log(blob); /* Blob {size: 12, type: "text/plain"} */
预览图片
拿到了一个Blob对象,该对象对应一个图片,可以使用下面的方式预览:
cropper.getCroppedCanvas().toBlob(function(img) { var image2 = document.getElementById('avatar2'); image2.src=URL.createObjectURL(img); });
- img 是个图片Blob对象
- avatar2 是个 html img 元素
示例
<!DOCTYPE html> <html lang="zh" > <head> <meta charset="utf-8"> </head> <body class="white-bg"> <a id="id1" href="#" rel="external nofollow" >blob</a> <script type="text/javascript"> var blob = new Blob(["Hello World!"],{type:"text/plain"}); var id1Element = document.getElementById("id1"); id1Element.href = URL.createObjectURL(blob); </script> </body> </html>
到此这篇关于JavaScript中URL和Blob的具体实现的文章就介绍到这了,更多相关JavaScript URL和Blob内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Js 利用正则表达式和replace函数获取string中所有被匹配到的文本(推荐)
这篇文章主要介绍了Js 利用正则表达式和replace函数获取string中所有被匹配到的文本,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧2018-10-10javascript下高性能字符串连接StringBuffer类
使用StringBuffer类比使用加号节省50%左右的时间,大家对于大数据的连接最好使用这个方法。2010-08-08利用BootStrap的Carousel.js实现轮播图动画效果
这篇文章主要介绍了利用BootStrap的Carousel.js实现轮播图动画效果的相关资料,需要的朋友可以参考下2016-12-12
最新评论