新闻中心
J*aScript文件操作_Blob与Stream API详解
Blob和Stream API是现代Web文件处理的核心,Blob用于创建和操作二进制数据对象,支持生成临时URL实现文件下载或切片上传;ReadableStream则通过流式读取避免大文件加载的内存压力,适用于进度监控、大型CSV生成等场景。两者结合可高效实现文件的分块传输与动态生成,提升性能。需注意内存释放、流不可重复读及浏览器兼容性问题。掌握它们意味着掌握前端高效文件处理的关键能力。

在现代Web开发中,J*aScript处理文件的能力越来越强。虽然浏览器出于安全考虑限制了对本地文件系统的直接访问,但通过 Blob 和 Stream API,我们可以高效地操作文件数据,实现下载、上传、切片、压缩等复杂功能。本文将深入讲解这两个核心API的使用场景与实践方法。
Blob:二进制大对象的基础用法
Blob(Binary Large Object)表示不可变的原始二进制数据,常用于处理图片、视频、PDF等文件类型。它不依赖磁盘路径,而是以内存中的数据块形式存在。
创建一个Blob非常简单:
const data = 'Hello, this is a text file content';
const blob = new Blob([data], { type: 'text/plain' });
你可以为Blob指定MIME类型,比如 image/png 或 application/pdf。之后可以通过URL.createObjectURL生成临时URL供下载或显示:
const url = URL.createObjectURL(blob);
const a = document.createElement('a');
a.href = url;
a.download = 'hello.txt';
a.click();
URL.revokeObjectURL(url); // 释放内存
Blob还支持切片操作,类似数组的slice方法,适合大文件分块上传:
const chunk = blob.slice(0, 1024, 'text/plain'); // 取前1KB
ReadableStream:流式处理大数据
当处理大文件时,一次性加载到内存可能导致性能问题。而 ReadableStream 允许我们以“流”的方式逐步读取数据,提升效率并降低内存占用。
现代浏览器中,fetch响应体就是一个可读流:
const response = await fetch('/large-file.txt');
const reader = response.body.getReader();
const decoder = new TextDecoder();
while (true) {
const { done, value } = await reader.read();
if (done) break;
console.log(decoder.decode(value)); // 分段处理内容
}
你也可以手动创建流:
星辰Agent
科大讯飞推出的智能体Agent开发平台,助力开发者快速搭建生产级智能体
378
查看详情
const stream = new ReadableStream({
start(controller) {
controller.enqueue(new TextEncoder().encode('Part 1\n'));
controller.enqueue(new TextEncoder().encode('Part 2\n'));
controller.close();
}
});
之后可以将其转换为Response或Blob进行进一步操作:
const response = new Response(stream); const blob = await response.blob();
结合Blob与Stream的实际应用场景
在真实项目中,两者经常配合使用。例如实现一个大文件下载进度监控:
async function downloadWithProgress(url, onProgress) {
const response = await fetch(url);
const contentLength = response.headers.get('Content-Length');
const total = parseInt(contentLength, 10);
let loaded = 0;
const chunks = [];
const reader = response.body.getReader();
while (true) {
const { done, value } = await reader.read();
if (done) break;
chunks.push(value);
loaded += value.length;
onProgress(loaded / total);
}
const fullBlob = new Blob(chunks);
return fullBlob;
}
另一个常见用途是生成大型CSV文件而不卡顿页面:
function generateLargeCSVStream(rows) {
return new ReadableStream({
async start(controller) {
for (const row of rows) {
const line = row.join(',') + '\n';
controller.enqueue(new TextEncoder().encode(line));
}
controller.close();
}
});
}
// 使用
const stream = generateLargeCSVStream(data);
const response = new Response(stream);
const blob = await response.blob();
const url = URL.createObjectURL(blob);
兼容性与注意事项
Blob在所有现代浏览器中都已广泛支持。ReadableStream属于WHATWG Stream标准,在主流浏览器中可用,但在旧版IE或部分移动浏览器中可能受限。
使用时注意以下几点:
- 每次调用
URL.createObjectURL()后应尽快调用revokeObjectURL()防止内存泄漏 - 流一旦关闭或读取完毕,不能重复读取,需重新请求
- 在Service Worker或Worker线程中也能使用Stream,适合后台任务
- 某些环境下(如Node.js),需使用polyfill或Node原生stream模块
基本上就这些。掌握Blob和Stream API,能让你更灵活地处理文件相关需求,从简单的下载到复杂的流式传输都能游刃有余。关键是理解数据不再必须“全量加载”,而是可以“逐步流动”这一理念。
以上就是J*aScript文件操作_Blob与Stream API详解的详细内容,更多请关注其它相关文章!
# 电商网站前端优化
# 上传
# 第三方
# 情况下
# 图片处理
# 这一
# 二进制数
# 服务好的网站推广哪家好
# 宜黄seo百度优化
# 加载
# 十堰网站搜索优化公司
# 推广网站排名案例
# 学习seo培训学费
# 网站优化专业生产
# 唐海网络推广网站广告
# 重庆网站建设要求
# 全网营销品牌推广
# blob
# 流式
# 大文件
# 器中
# p
# ai
# csv
# app
# 浏览器
# 大数据
# node
# node.js
# 前端
# js
# java
# javascript
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
PS5 Pro有点优势但不多! 《燕云十六声》PS5平台与PC性能画面对比
快速CSGO开箱网站指南 CSGO开箱平台推荐
Golang如何使用new_Go new分配内存机制讲解
移动端XML文件怎么转换成Excel 手机和平板上的解决方案
地铁跑酷免费秒玩入口链接 地铁跑酷小游戏免费秒玩网站
Golang如何优化内存分配与垃圾回收_Golang内存管理与GC优化实践
poki免费入口快捷访问 poki人气小游戏直接玩站点
SteamMachine定价或为699美元 大家想入手吗?
wps文字怎么插入目录并自动更新_wps文字如何插入目录并自动更新方法
MAC如何安全彻底地删除文件_MAC使用终端命令确保文件无法被恢复
AWS EC2实例间SQL Server连接超时:安全组配置与故障排除指南
响应式图片在网页设计中的正确实现方法
J*a递归快速排序中静态变量导致数据累积的陷阱与解决方案
一加 14R 快充无反应_一加 14R 充电优化
qq音乐在线播放入口_qq音乐电脑版登录链接
2025AO3夸克浏览器通道_AO3手机HTTPS安全入口分享
Win11怎么关闭快速启动_Win11彻底关机设置教程
服务端验证_j*ascript输入检查
Python自定义类排序:解决lambda键值访问TypeError的实践指南
Golang如何使用net/url解析URL_Golang URL解析与处理方法
QQ邮箱正确登录入口_QQ邮箱官方网站使用地址
Win11如何开启讲述人功能 Win11屏幕阅读器(讲述人)开启与关闭【教程】
拷贝漫画电脑版官网入口 拷贝漫画(PC版)在线直达
支付宝解绑银行卡步骤_支付宝如何解除绑定银行卡
深入理解Promise链:如何在catch后中断then的执行
抖音商城签到领现金是真的吗_抖音商城签到奖励与提现说明
Go语言中JSON数据解析与字段访问教程
如何使 Jest 模拟函数默认抛出错误以提高测试效率
Win11怎么用U盘重装系统 Win11制作启动盘并重装系统完整教程【详解】
Composer的 "conflict" 字段有什么用_如何声明不兼容的包以避免依赖冲突
Yandex搜索引擎官网入口_俄罗斯Yandex免登录一键直达
格力空气能E5故障代码是什么情况_格力空气能E5代码解析与应对措施
CSS Flexbox如何实现多行排列_flex-wrap wrap自动换行显示
学习通网页版官方登录 超星学习通电脑端入口指南
c++中的std::basic_string的SSO优化_c++短字符串优化深度解析
解决Django多数据库/多Schema环境下外键迁移问题
Spyder启动失败:字体文件权限拒绝错误解决方案
浏览器打开即用 美图秀秀网页版入口
解决移动端滚动问题的overflow属性应用指南
如何使用Rector自动化升级旧代码_通过Composer安装和配置Rector进行代码重构
如何更改在 Excel 中打开超链接时的默认浏览器
sublime怎么覆盖插件的默认快捷键_sublime快捷键优先级与设置
铁路12306的积分有效期是多久_铁路12306积分有效期说明
composer 和 npm/yarn 在管理依赖方面有什么核心思想差异?
打开就能玩的植物大战僵尸 植物大战僵尸网页版传送门
C++的std::mdspan是什么_C++23中用于操作多维数组的非拥有视图
J*aScript井字棋(Tic-Tac-Toe)核心交互逻辑实现教程
Mac终端命令大全_Mac常用Terminal指令速查
解决Tabulator日期时间排序问题的专业指南
学习通网页版快速入口 学习通官网网页版直接打开


2025-12-04
浏览次数:次
返回列表
器兼容性问题。掌握它们意味着掌握前端高效文件处理的关键能力。