用AI理解前端文件类型

开始讲解 第一步:数据获取

vbnet 复制代码
By fetch/xhr
By FileReader/Response
  • fetch/xhr : 使用 fetchXMLHttpRequest (XHR) 从网络获取数据。这些方法可以用来请求服务器上的资源,返回的数据可以是各种格式,包括 ArrayBuffer
  • FileReader/Response : 使用 FileReader 对象读取本地文件,或者处理 Response 对象中的数据。FileReader 可以将文件内容读取为 ArrayBuffer图表模拟:
sql 复制代码
+----------------+       +------------------+
|  Network Data  |------>|  fetch/xhr       |
+----------------+       +------------------+
                            |
                            |
                            v
+----------------+       +------------------+
|  Local File    |------>|  FileReader      |
+----------------+       +------------------+

第二步:数据处理

arduino 复制代码
typedArray.buffer
new TypedArray(buffer)
ArrayBuffer
  • typedArray.buffer : TypedArray 对象有一个 buffer 属性,指向其底层的 ArrayBuffer
  • new TypedArray(buffer) : 可以通过 ArrayBuffer 创建新的 TypedArray 对象,例如 new Uint8Array(buffer)
  • ArrayBuffer : 这是一个用于表示通用的、固定长度的二进制数据缓冲区的对象。 图表模拟:
lua 复制代码
+------------------+       +------------------+
|  ArrayBuffer    |<------>|  TypedArray      |
+------------------+       +------------------+
                            |
                            |
                            v
+------------------+       +------------------+
|  Buffer Data     |<------>|  typedArray.buffer |
+------------------+       +------------------+

第三步:Blob 创建

arduino 复制代码
new Blob([buffer], {type: 'application/octet-stream'})
  • Blob 创建 : 使用 ArrayBuffer 创建 Blob 对象,指定 MIME 类型。Blob 对象表示不可变的、原始数据的类文件对象。 图表模拟:
sql 复制代码
+------------------+       +------------------+
|  ArrayBuffer    |------>|  new Blob()      |
+------------------+       +------------------+
                            |
                            |
                            v
+------------------+       +------------------+
|  Blob Object     |<------>|  {type: 'application/octet-stream'} |
+------------------+       +------------------+

第四步:数据表示

css 复制代码
URL.createObjectURL(blob)
toDataURL
Data URL
Object URL
  • URL.createObjectURL(blob) : 创建一个表示指定 Blob 对象的 URL。
  • toDataURL : Canvas 对象的方法,返回一个表示 Canvas 内容的 Data URL。
  • Data URL: 一种把小文件嵌入到网页中的方法,直接在 URL 中包含文件的数据。
  • Object URL : 一种指向内存中 Blob 对象的 URL,通常用于显示媒体文件或触发下载。 图表模拟:
sql 复制代码
+------------------+       +------------------+
|  Blob Object     |------>|  URL.createObjectURL() |
+------------------+       +------------------+
                            |
                            |
                            v
+------------------+       +------------------+
|  Object URL      |<------>|  blob:http://<origin>/<uuid> |
+------------------+       +------------------+
+------------------+       +------------------+
|  Canvas Object   |------>|  toDataURL()     |
+------------------+       +------------------+
                            |
                            |
                            v
+------------------+       +------------------+
|  Data URL        |<------>|  data:[<mediatype>][;base64],<data> |
+------------------+       +------------------+

第五步:数据保存

vbnet 复制代码
By FileSaver 下载
  • FileSaver : 一个 JavaScript 库,用于将 BlobFile 对象保存为文件,触发浏览器的下载行为。 图表模拟:
sql 复制代码
+------------------+       +------------------+
|  Blob/File Object|------>|  FileSaver.saveAs() |
+------------------+       +------------------+
                            |
                            |
                            v
+------------------+       +------------------+
|  Downloaded File |<------>|  Saved File      |
+------------------+       +------------------+

结束讲解 通过上述步骤,我们从数据的获取、处理、表示到保存,完整地理解了图片中的内容。虽然无法直接绘制图表,但希望这个分步骤的文本描述能帮助您构建一个清晰的概念框架。 [\boxed{ 通过上述分步骤的讲解,我们从数据的获取、处理、表示到保存,完整地理解了图片中的内容。虽然无法直接绘制图表,但希望这个分步骤的文本描述能帮助您构建一个清晰的概念框架。 }]

相关推荐
C澒1 分钟前
前端整洁架构(Clean Architecture)实战解析:从理论到 Todo 项目落地
前端·架构·系统架构·前端框架
C澒7 分钟前
Remesh 框架详解:基于 CQRS 的前端领域驱动设计方案
前端·架构·前端框架·状态模式
Charlie_lll10 分钟前
学习Three.js–雪花
前端·three.js
onebyte8bits27 分钟前
前端国际化(i18n)体系设计与工程化落地
前端·国际化·i18n·工程化
C澒36 分钟前
前端分层架构实战:DDD 与 Clean Architecture 在大型业务系统中的落地路径与项目实践
前端·架构·系统架构·前端框架
BestSongC40 分钟前
行人摔倒检测系统 - 前端文档(1)
前端·人工智能·目标检测
0思必得01 小时前
[Web自动化] Selenium处理滚动条
前端·爬虫·python·selenium·自动化
Misnice1 小时前
Webpack、Vite、Rsbuild区别
前端·webpack·node.js
青茶3601 小时前
php怎么实现订单接口状态轮询(二)
前端·php·接口
大橙子额2 小时前
【解决报错】Cannot assign to read only property ‘exports‘ of object ‘#<Object>‘
前端·javascript·vue.js