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

相关推荐
兆子龙20 分钟前
像 React Hook 一样「自动触发」:用 Git Hook 拦住忘删的测试代码与其它翻车现场
前端·架构
兆子龙1 小时前
用 Auto.js 实现挂机脚本:从找图点击到循环自动化
前端·架构
SuperEugene1 小时前
表单最佳实践:从 v-model 到自定义表单组件(含校验)
前端·javascript·vue.js
昨晚我输给了一辆AE861 小时前
为什么现在不推荐使用 React.FC 了?
前端·react.js·typescript
不会敲代码11 小时前
深入浅出 React 闭包陷阱:从现象到原理
前端·react.js
不会敲代码11 小时前
React性能优化:深入理解useMemo和useCallback
前端·javascript·react.js
Dilettante2581 小时前
我的 Monorepo 实践经验:从基础概念到最佳实践
前端·前端工程化
只会cv的前端攻城狮1 小时前
Elpis-Core — 融合 Koa 洋葱圈模型实现服务端引擎
前端·后端
Java小卷2 小时前
流程设计器为啥选择diagram-js
前端·低代码·工作流引擎
HelloReader3 小时前
Isolation Pattern(隔离模式)在前端与 Core 之间加一道“加密网关”,拦截与校验所有 IPC
前端