百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

前端面试-Blob分析,不常用,就怕面试官有毒

myzbx 2025-05-09 20:31 11 浏览

一、Blob是什么?能用来装什么?

Blob(Binary Large Object)就像前端世界的"集装箱",专门用来装载二进制数据。你可以把它想象成一个能装下图片、音视频、文本甚至加密数据的万能盒子。它的特别之处在于:不可变(一旦创建内容无法修改)、类文件对象(能像操作文件一样操作它)。

举个接地气的例子:当用户上传头像时,浏览器就会把图片打包成一个Blob对象;当你在网页预览PDF时,底层也是通过Blob处理二进制数据流。

Blob使用场景

  1. 文件上传与下载

<input type="file">获取用户文件时,得到的 File 对象其实继承自 Blob。通过 URL.createObjectURL()可以生成临时链接实现本地预览,还能配合<a download />实现无后端文件下载。

Bash
// 下载文本文件示例
const data = new Blob(['Hello World'], {type: 'text/plain'});
const url = URL.createObjectURL(data);
const a = document.createElement('a');
a.href = url;
a.download = 'hello.txt';
a.click();
  1. 大文件分片上传

处理大文件时,用slice()方法将Blob切割成多个碎片上传,既避免一次性传输卡死,又能实现断点续传:

Bash
const chunkSize = 1024 * 1024; // 1MB分片
let start = 0;
while(start < file.size) {
  const chunk = file.slice(start, start + chunkSize);
  uploadChunk(chunk); // 上传分片
  start += chunkSize;
}
  1. Canvas图像处理
    将Canvas绘图结果转成Blob,可直接上传或生成缩略图:
canvas.toBlob(blob => {
  const img = new Image();
  img.src = URL.createObjectURL(blob);
}, 'image/jpeg', 0.8);
  1. WebSocket实时传输
    配合ArrayBuffer处理音视频流数据,实现直播、视频会议等场景:
websocket.onmessage = e => {
  const blob = new Blob([e.data], {type: 'video/webm'});
  const video = document.getElementById('video');
  video.src = URL.createObjectURL(blob);
};

高频面试题解析

  1. Blob与File有什么区别?
    File继承自Blob,增加了文件名、修改时间等元信息。当用户通过<input>选择文件时,得到的就是File对象。
  2. Blob如何转Base64?
    使用FileReader读取:
const reader = new FileReader();
reader.readAsDataURL(blob);
reader.onload = () => console.log(reader.result);
  1. 如何实现零拷贝下载大文件?
    通过fetch获取响应体的Blob数据流,搭配streams API实现边下载边写入磁盘,避免内存爆仓。
  2. Blob在性能优化中的应用?
  • 使用 createImageBitmap 解码图片,避免主线程卡顿
  • 通过 compression streams API压缩传输体积
  • Web Worker中处理Blob避免阻塞UI

避坑指南

  • 内存泄漏:用完的Blob URL要及时用 URL.revokeObjectURL() 释放
  • 类型匹配:指定正确的MIME类型,如application/pdf
  • 兼容性处理:Safari对部分Blob方法支持较差,需做polyfill

Blob在前端开发中其实是相当给力的工具,掌握它能解锁文件处理、媒体操作、性能优化等高阶能力。建议通过Chrome DevTools的Memory面板观察Blob内存占用,在实战中深化理解。

Blob工具我觉得把上面的内容稍微记一下,面试中能说上点,实战中要有个印象,知道什么需求可以用上这个工具就行了。

相关推荐

路痴的福音 谷歌地图AR实景导航Live View正式上线

2月份起,谷歌地图开始测试一项新功能,即是在行人导航功能中加入AR实景导航。用户可以通过设备屏幕,在实际的街道中见到路线指示,使导航功能不只在地图上,而是更融合在真实环境中。谷歌地图AR实景导航(图源...

Google地图怎么设置中文 谷歌地图app设置语言为中文

Google地图是一款知名的地图导航客户端,这是一款很好用的地图软件,Google地图怎么设置中文呢,不少人可能不是很清楚,下面就和小编一起来看看吧!Google地图怎么设置中文方法1、点击打开谷歌地...

谷歌地图说这里能过

来源:日本沙雕日常谷歌地图说这里能过#微博新鲜事#

谷歌地图已可离线导航 仅安卓机可用

谷歌已经在今年的谷歌IO大会上确认了地图离线导航功能,如今该功能已经可以在安卓机上使用了。这对网络资源较为贫瘠且相对昂贵的国家来说可谓提供了便利。用户需要提前下载所需旅程的部分地图,虽然不能获得实时路...

谷歌地图测试速度更快的AR实时视图

上个月谷歌为了庆祝谷歌地图成立15周年,为谷歌地图推出了新的图标,并且重新设计了移动应用程序。谷歌还预览了一些即将推出的功能,现在正在测试地图导航之外更快的实时视图(LiveView)访问。谷歌之...

谷歌地图新功能 离线地图可导航和搜索

【中关村在线软件资讯】5月29日消息:在今天凌晨召开的GoogleI/O开发者大会上,谷歌公布了一些关于地图的新功能。谷歌地图离线模式新版谷歌地图有更好用的离线地图,可以在无网络的情况下搜索地点、查...

谷歌地图变这样,谁还花钱去旅游?

足不出户,在手机上能身临其境的游览世界各地。文章来源:创下一个新ID:cxygx1作者:创新君编辑:卝生话说在前天的GoogleI/O2022开发人员活动中,谷歌推出了一种全新的地图模式,可以...

新版谷歌地图将添新功能:知道你想去哪儿

据外媒TheVerge报道,谷歌即将为安卓版谷歌地图增加一些新的功能,从而使之变得更加智能,比如可以推算出用户的目的地等。新版谷歌地图将添新功能(图片来自TheVerge)报道称,升级后的谷歌地图将会...

谷歌地图安卓版获效率改进,11.136.x更新引入“表单风格”卡片

IT之家7月16日消息,谷歌在今年2月宣布将对自家地图应用进行大修,目前相关更新已经实装入谷歌地图11.136.x版本中,主要围绕UI进行效率改进。谷歌提到,现在用户在查找地址时,...

谷歌地图安卓/iOS版界面大修,超漂亮

IT之家(www.ithome.com):谷歌地图安卓/iOS版界面大修,超漂亮IT之家报道,Android5.0已经正式到来,谷歌旗下的应用为了迎接安卓5.0都采用了全新的MaterialDes...

谷歌地图在美国启用“美国湾”称呼

参考消息网2月11日报道据法新社2月11日报道,美国总统特朗普10日对谷歌地图将墨西哥湾更名为“美国湾”表示欢迎,这符合他在1月底重返白宫后签署的法令之一。这一占超主导地位的地图服务现在为位于美国的用...

外交部回应谷歌地图涉南海标注:南海一直是国际社会公认通用地名,被广泛接受

【环球时报-环球网报道记者李萌】在4月15日外交部例行记者会上,有记者提问称,据报道,谷歌地图显示了“西菲律宾海”的名称,此前这里显示的是南海。有人称这有助于保护菲律宾的主权,请问中方对此有何评论?...

谷歌地图首曝数据:覆盖全球98%居住区,已拍千万英里街景

12月13日,谷歌透露了其街景车(StreetViewcar)等设备为绘制世界地图所做的工作。目前,谷歌已经捕获了超过1000万英里的街景图像,这个距离相当于绕地球400圈。旗下航空地图服务谷歌地...

美媒:谷歌称,当联邦地图作出更改时,谷歌地图将使用“迪纳利峰”及“墨西哥湾”新名称

来源:环球网【环球网报道】据美国全国广播公司(NBC)等媒体报道,美国谷歌公司27日称,当联邦地图作出更改时,谷歌地图将使用“迪纳利峰”和“墨西哥湾”的新名称,即“麦金利山”和“美国湾”。本月20日...

谷歌地图迎来15周年重大更新 界面重新设计 新增贴心功能

昨日,恰逢谷歌地图15周年生日,谷歌地图便迎来重大更新。不仅仅界面重新设计,还添加了许多贴心功能。名为“TransitAttributes”的新功能会根据过去用户共享的详细信息,向人们提供有关公共场...