跳到主要内容

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
支持异步编程,包括 FutureStream 等类。
package:async 提供了围绕 FutureStream 类型的额外实用工具。
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_interopdart:js_interop_unsafe
dart:svg (旧版)
可缩放矢量图形。
请改用 package:web
dart:web_audio (旧版)
浏览器中的高保真音频编程。
请改用 package:web
dart:web_gl (旧版)
浏览器中的 3D 编程。
请改用 package:web