目录

JavaScript中URL和Blob

JavaScript中URL和Blob

常用于处理文件数据、图像数据、音频数据等。Blob对象通常用于在客户端处理文件,如上传文件、下载文件、处理图像等操作。Blob对象可以通过Blob构造函数创建,也可以通过其他方式获取,比如从File对象中获取。

使用场景

  • 文件上传:将用户选择的文件转换为Blob对象,然后通过Ajax请求将Blob对象发送到服务器。
  • 文件下载:将服务器返回的文件数据转换为Blob对象,然后通过URL.createObjectURL()生成下载链接,供用户下载。
  • 图片处理:将图片文件转换为Blob对象,然后可以进行压缩、裁剪等操作。
  • 音频视频处理:处理音频、视频文件时,也可以使用Blob对象来操作二进制数据。

相关API

  1. slice(start, end, contentType):从Blob对象中提取指定范围的数据,返回一个新的Blob对象。参数start和end分别表示提取数据的起始和结束位置(单位为字节),contentType是可选的,表示新Blob对象的MIME类型。
javascript 复制代码
const blob = new Blob(["Hello, world!"]);
const slicedBlob = blob.slice(0, 5, "text/plain");
  1. size:返回Blob对象的大小,单位为字节。
javascript 复制代码
const blob = new Blob(["Hello, world!"]);
console.log(blob.size); // 输出 13
  1. type:返回Blob对象的MIME类型。
javascript 复制代码
const blob = new Blob(["Hello, world!"], { type: "text/plain" });
console.log(blob.type); // 输出 "text/plain"
  1. arrayBuffer():将Blob对象转换为ArrayBuffer对象。
javascript 复制代码
const blob = new Blob(["Hello, world!"]);
blob.arrayBuffer().then(arrayBuffer => {
    // 处理ArrayBuffer对象
});

注意事项

如果不想再使用这个对象。可以调用URL.revokeObjectURL(你的url),最好在不使用时候就释放,减少占用资源

本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
拉不动的猪3 分钟前
设计模式之------单例模式
前端·javascript·面试
xiegwei5 分钟前
Kotlin 和 spring-cloud-function 兼容问题
开发语言·kotlin·springcloud
Alt.926 分钟前
SpringMVC基础二(RestFul、接收数据、视图跳转)
java·开发语言·前端·mvc
念九_ysl1 小时前
深入解析Java内存与缓存:从原理到实践优化
java·开发语言·缓存
似水এ᭄往昔1 小时前
【C语言】预处理(下)(C语言完结篇)
c语言·开发语言
Y1nhl2 小时前
基础算法:滑动窗口_python版本
开发语言·python·算法·力扣·滑动窗口
长流小哥2 小时前
Linux线程属性与多线程开发:API详解与实战代码解析
linux·c语言·开发语言·文件
YanaDH2 小时前
Quill富文本编辑器支持自定义字体(包括新旧两个版本,支持Windings 2字体)
前端·javascript
专注VB编程开发20年2 小时前
C#.NET模拟用户点击按钮button1.PerformClick自动化测试
开发语言·自动化测试·c#·vb.net
wht65872 小时前
Linux--进程信号
linux·运维·服务器·开发语言·c++