Dart 的核心库
Dart 拥有一套丰富的核心库,为许多日常编程任务提供基本功能,例如处理对象集合(dart:collection
)、进行计算(dart:math
)以及数据编码/解码(dart:convert
)。更多 API 可在常用包中找到。
库概览 (Library tour)
#以下指南介绍了如何使用 Dart 核心库的主要特性。它们仅提供概述,并非详尽无遗。无论何时您需要有关库或其成员的更多详细信息,请查阅Dart API 参考。
- dart:core
- 内建类型、集合及其他核心功能。此库会自动导入到每个 Dart 程序中。
- dart:async
- 支持异步编程,包括 Future 和 Stream 等类。
- dart:math
- 数学常数和函数,以及随机数生成器。
- dart:convert
- 用于在不同数据表示之间转换的编码器和解码器,包括 JSON 和 UTF-8。
- dart:io
- 适用于可使用 Dart VM 的程序的 I/O,包括 Flutter 应用、服务器和命令行脚本。
- dart:js_interop
- 与 Web 平台互操作的 API。与
package:web
一起,dart:js_interop
替代了dart:html
。
如前所述,这些页面只是概述;它们仅涵盖少量 dart:* 库,不包括第三方库。
要了解 Dart 在不同平台上支持的所有库的概述,请查看下面的多平台库、原生平台库和Web 平台库列表。
查找库信息的其他地方包括 pub.dev 网站和Dart Web 开发者库指南。您可以在Dart API 参考中找到所有 dart:* 库的 API 文档,如果您使用 Flutter,则可在Flutter API 参考中找到。
要详细了解 Dart 语言,请查阅语言文档和示例。
多平台库
#下表列出了适用于所有Dart 平台的 Dart 核心库。
库 | 说明 |
---|---|
dart:core 所有 Dart 程序的内建类型、集合及其他核心功能。 | |
dart:async , package:async 支持异步编程,包括 Future 和 Stream 等类。package:async 提供了围绕 Future 和 Stream 类型的额外实用工具。 | |
dart:collection , package:collection 补充 dart:core 中集合支持的类和实用工具。package:collection 提供了进一步的集合实现以及用于处理集合的函数。 | |
dart:convert , package:convert 用于在不同数据表示之间转换的编码器和解码器,包括 JSON 和 UTF-8。 package:convert 提供了额外的编码器和解码器。 | |
dart:developer 与调试器和检查器等开发者工具进行交互。 | 仅限原生 JIT 和开发 JavaScript 编译器 |
dart:math 数学常数和函数,以及随机数生成器。 | |
dart:typed_data , package:typed_data 可高效处理固定大小数据(例如,无符号 8 字节整数)和 SIMD 数字类型的列表。 package:typed_data 提供了更多处理类型化数据的类和函数。 |
原生平台库
#下表列出了适用于Dart 原生平台(AOT 和 JIT 编译代码)的 Dart 核心库。
库 | 说明 |
---|---|
dart:ffi , package:ffi 允许 Dart 代码使用原生 C API 的外部函数接口。 package:ffi 包含实用工具,包括支持转换 Dart 字符串和 C 字符串。 | |
dart:io , package:io 为非 Web 应用提供文件、套接字、HTTP 及其他 I/O 支持。 package:io 提供了包括支持 ANSI 颜色、文件复制和标准退出代码等功能。 | |
dart:isolate 使用 isolates 进行并发编程:类似于线程的独立 worker。 | |
dart:mirrors 支持内省和动态调用的基本反射功能。 | 实验性 仅限原生 JIT(不包括 Flutter) |
Web 平台库
#下表列出了适用于Dart Web 平台(编译为 JavaScript 的代码)的 Dart 核心库。推荐使用的最新工具以粗体显示,旧工具以斜体显示(访问JavaScript 互操作性了解更多信息)。
库 | 说明 |
---|---|
package:web 基于 JS 互操作构建的轻量级浏览器 API 绑定 | 替换所有 dart:* Web 库。请阅读迁移指南。 |
dart:js_interop 与 JavaScript 和浏览器 API 的互操作。 | 替换 package:js 。 |
dart:js_interop_unsafe 动态操作 JavaScript 对象的实用方法。 | 替换 dart:js_util 。 |
dart:html (旧版)基于 Web 应用的 HTML 元素及其他资源。 | 请改用 package:web 。 |
dart:indexed_db (旧版)支持索引的客户端键值存储。 | 请改用 package:web 。 |
dart:js , dart:js_util , package:js (旧版)用于 JS 互操作的低级原语和高级注解。 | 请改用 dart:js_interop 或 dart:js_interop_unsafe 。 |
dart:svg (旧版)可缩放矢量图形。 | 请改用 package:web 。 |
dart:web_audio (旧版)浏览器中的高保真音频编程。 | 请改用 package:web 。 |
dart:web_gl (旧版)浏览器中的 3D 编程。 | 请改用 package:web 。 |