Dart 的核心库
Dart 拥有丰富的核心库,为许多日常编程任务提供基本功能,例如处理对象集合 (dart:collection
)、进行计算 (dart:math
) 以及编码/解码数据 (dart:convert
)。其他 API 可在常用包中找到。
库导览
#以下指南介绍了如何使用 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:html
- 用于基于浏览器的应用的 DOM 和其他 API。我们现在建议使用
package:web
而不是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 使用隔离进行并发编程:类似于线程的独立工作进程。 | |
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 。 |
除非另有说明,本网站上的文档反映的是 Dart 3.6.0 版本。页面最后更新于 2024-11-17。 查看源代码 或 报告问题。