在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
支持 Apple Silicon,增加了默认的 lint、更好的工具和新的语言功能提高生产力。 本月,我们发布了 Dart SDK 2.14 的正式版,新的版本旨在通过独特的可移植性、生产力和稳健性组合来打造构建应用程序的最佳平台。这一次,我们对 Apple Silicon 提供了更好的支持,并提供了许多增强生产力的功能,例如用于通过代码样式分析在你编写代码时捕获错误的标准 lint 代码规则、更快的发布工具、更好的级联代码格式以及一些小的语言特性更新。 自 Apple 在 2020 年末发布新的 Apple 芯片 处理器芯片以来,我们一直致力于更新 Dart SDK 以增加对新处理器上的原生运行支持。所需的更新已经在 dev 渠道中提供了一段时间,过去一个月,beta 渠道也提供了支持,从 Dart 2.14.1 开始,可以在 Dart stable 渠道中使用啦。当你 下载 一个 macOS 的 SDK 时,确保要选择 ARM64 选项。请注意,与 Flutter SDK 中捆绑的 Dart SDK 还没有支持这些改进。 这些支持包括了在 Apple 芯片上运行 SDK 和 Dart 虚拟机,也支持了在 Apple 芯片上编译运行的可执行文件 (使用 dart compile 命令)。由于 Dart 命令行工具使用原生 Apple 芯片支持,因此它们的启动速度要快得多。 开发者们通常会更偏向让代码遵循某种风格。这些规则中有许多并不只是风格上的偏好 (比如众所周知的 tab 与空格的讨论),而且涵盖了可能导致错误或引入错误的编码风格。例如,Dart 风格指南要求对所有控制流结构使用花括号,如 if-else 语句。这可以防止经典的「悬空 else」问题,即在有多个嵌套的 if-else 语句时存在歧义。另一个例子则是类型推断,虽然在声明具有初始值的变量时,使用类型推断没有问题,但在 声明未初始化的变量 时手动指定类型就相当重要,这样可以确保类型安全。 保持良好代码风格当然也可以选择某种人工审查的形式,也就是我们熟悉的 code review。但是,在编写代码时运行静态分析来强制要求执行规则,通常要更为有效。 在 Dart 中,这种静态分析是高度 可配置的,我们有 数百条样式规则 (也称为 lints)。有了这么丰富的选项,可能会导致我们不知道选择要启用哪个规则。Dart 团队维护了一个 Dart 风格指南,它描述了我们认为编写和设计 Dart 代码的最佳实践,在此之前我们还没有提供正式的官方风格指南的 linter 规则。 许多开发者,也包括 pub.dev 网站的 评分 引擎都在使用一个名为 pedantic 的 lint 规则。然而,pedantic 起源于谷歌内部的 Dart 风格指南,由于历史原因,它与一般的 Dart 风格指南并不相同。因此,Flutter 框架从未使用过 pedantic 规则集,而是有自己的一套规范性规则。 这听起来可能有点乱,不过确实如此。但是在这次的版本发布中,我们很高兴地宣布,我们现在拥有了一套全新的 lint 集合来实现样式指南,并且 Dart 和 Flutter SDK 已更新为默认情况下将这些规则集用于新项目。这些规则集包括:
如果你现有的项目中使用了 pedantic,我们强烈建议你升级到这些新规则集。从 pedantic 升级 只需几步。 我们对 Dart 格式化器格式化 级联 代码的方式进行了一些优化。以前,格式化器在某些情况下会产生混乱的格式化。例如,在这个例子中,
看上去它总会被
其他的变化还涉及如何对有多个级联的行进行格式化,以及级联一般缩进多远。我们还大大提高了包含级联的代码的格式化速度;在为 协议缓冲区 生成的 Dart 代码中,我们看到格式化速度 有关该问题的所有详细信息,请参阅和跟踪这个 Pull Request。 目前,当你 发布 一个 package 到 pub.dev 社区仓库时, Dart 2.14 中更新的 虽然 在 Dart 2.14 之前,对
在 Dart 2.14 中, Dart 2.14 还包含了一些小的语言特性。这一次,我们把重点放在更具体的改进上,这些改进可能只是一些细小的功能,但却能实现以前不支持的更专业的用例。 首先,我们添加了一个新的 三重移位 运算符 ( 我们还删除了对类型参数的旧限制,该限制不允许使用泛型函数类型作为类型参数。以下所有内容在 2.14 之前都是无效的,但现在是允许的:
最后,我们对注解类型做了一个小小的调整 (像 @Deprecated 这样注解在 Dart 代码中通常用来捕获元数据)。以前注解不能传递类型参数,所以像 我们对核心 Dart package 和代码库进行了许多增强,包括:
Dart 2.14 还包含一些较小的、已经 提前宣布过的 破坏性更新 (breaking changes)。预计这些变化只会影响一些特别的用例,这些破坏性更新如下: #46545: 取消对 ECMAScript5 的支持所有的现代浏览器 都已支持最新的 ECMAScript 版本,所以两年前我们 宣布了 一项计划,不再支持 ECMAScript 5 (ES5)。这使我们能够利用最新的 ECMAScript 的改进,生成更小的输出。在 Dart 2.14 中,这项工作已经完成,Dart Web 编译器不再支持 ES5 了,因此,较旧的浏览器 (例如 IE11 ) 将不再支持。 #46100: 弃用 stagehand、dartfmt 和 dart2native在 2020 年 10 月的 Dart 2.10 博客文章中,我们宣布了将所有 Dart CLI 开发人员工具组合成一个单一的组 #45451: 弃用 VM 原生扩展我们已经弃用了 Dart VM 的原生扩展,这是我们从 Dart 代码调用原生代码的旧机制。Dart FFI (外部功能接口) 是我们当前用于这个用例的机制,我们正在积极 发展 它以使其功能更加强大且易于使用。 我们在 3 月份的 Dart 2.12 版本中推出了健全的空安全。空安全是 Dart 最新的主要生产力特性,旨在帮助你避免空值错误,这是一类通常难以发现的错误。 自从我们上次更新以来,我们看到现有 package 和应用程序的迁移取得了巨大的进展,以实现空安全 的健全检查优势。对于 pub.dev 上的 package,前 250 名的 package 中 100% 都已支持了空安全,前 1000 名中有 94% 都支持。这意味着更多的开发者可以用完全 健全的空安全 来运行他们的应用。分析显示,56% 的 包含上述变化的增强型 Dart SDK 已经可以在 Dart 2.14.1 和 Flutter 2.5 SDK 中使用。我们希望你会喜欢这些新的改进和功能。 感谢 Dart 社区另外,我们想借此机会向 Dart 社区表示感谢。通过最近对编程语言调查的一些更新,可以看到 Dart 的势头很强劲。备受尊敬的 RedMonk 排名中 提到了 "Dart 的显著上升",并首次将 Dart 列入前 20 名。StackOverflow 的 2021 年开发者综合调查 同样让人欣喜。据报道,Dart 是开发人员最喜爱的第七种编程语言。我们真的很高兴看到 Dart 平台有持续的增长和发展势头。 感谢 flutter.cn 社区成员 (@AlexV525、@Vadaski、@MeandNi) 以及 Lynn 对本文的审校和贡献。 |
请发表评论