news 2026/5/4 0:12:54

Compose跨平台新版本来了!测试 API 全废弃,iOS 崩溃集中修复

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Compose跨平台新版本来了!测试 API 全废弃,iOS 崩溃集中修复

本次版本带来了全新的 v2 测试 API、一大波 iOS 崩溃修复,以及 Desktop 端的内存和性能优化。

测试 API 大升级:v2 来了

这次最大的变化是 UI 测试框架的升级。

旧版的runComposeUiTestrunSkikoComposeUiTestrunDesktopComposeUiTest全部标记为 deprecated,取而代之的是 v2 版本。

核心区别:v2 默认使用StandardTestDispatcher,替换了之前的UnconfinedTestDispatcher

这意味着什么?

UnconfinedTestDispatcher会立即执行协程,不走调度流程。写测试时确实方便,但也容易掩盖真实环境中的时序问题。StandardTestDispatcher更接近生产环境行为,测试结果更可靠。

另外,v2 还支持自定义effectContext,对于需要注入特定协程上下文的测试场景非常实用。

如果你的项目有跨平台 UI 测试,这次升级值得尽早适配。

Kotlin/JS 和 Wasm 用户注意

从这个版本开始,使用 Kotlin/JS 或 Kotlin/Wasm 编译目标,必须升级到 Kotlin 2.3.20

不是建议,是硬性要求。

如果你的项目还停留在旧版本 Kotlin,先升级编译器再升级 Compose。顺序不能反。

iOS 修了一堆崩溃

说实话,这次 iOS 的修复清单看得我心情复杂——一方面庆幸问题被解决了,另一方面感叹之前的坑确实不少。

重点修复包括:

文本输入相关的崩溃全面清理。启用usingNativeTextInput后,空文本框三击崩溃、自动纠错崩溃、键盘建议插入异常——这些让人抓狂的问题,这个版本统统修掉了。

iOS 15 兼容性修复。之前因为缺少UIWindowSceneGeometry符号会导致崩溃,如果你的 App 还需要支持 iOS 15,这个修复至关重要。

滚动和弹窗修复。Modal 视图中的滚动内容异常、ModalBottomSheetDialog的内容 inset 计算错误,都已修正。

无障碍访问大幅改善。无障碍元素结构现在更贴近 Android 语义节点,运行时元素聚焦问题也已解决。

你之前有没有遇到过这些问题?

桌面端端也没落下

桌面端这边有几个值得关注的改动:

内存泄漏修复。使用非默认compose.layers.type设置时,对话框会产生内存泄漏。这种问题往往在生产环境中才会暴露,很难排查,现在终于堵上了。

大量子节点的性能优化。如果你的界面有包含大量子元素的 traversal group(比如长列表的无障碍遍历),性能会有明显提升。

场景关闭时的任务清理。窗口关闭后,残留的定时任务不会再继续执行,避免了潜在的资源浪费和异常。

Compose Hot Reload 也同步升级到了 1.1.0-beta02。

Web 端的两个修复

Web 目标修了identityHashCode缓存不正确的问题。

还有一个跨平台的修复值得一提:iOS 上包含 emoji 的文本快速删除不生效的问题也解决了——虽然归在 Web 分类下,但实际影响的是 iOS 输入体验。

写在最后

Compose Multiplatform 的迭代速度越来越快了。

从这次更新能看出 JetBrains 的重心:iOS 端的稳定性是当前第一优先级。十多个 iOS 修复,覆盖了文本输入、无障碍、滚动、弹窗——这些都是生产环境中的高频场景。

对于正在用 CMP 做跨平台项目的团队来说,beta02 的质量提升是实打实的。建议尽早升级测试。

你的项目用上 Compose Multiplatform 了吗?iOS 端的体验怎么样?评论区聊聊。

[#ComposeMultiplatform](javascript:😉 [#Kotlin](javascript:😉 [#跨平台开发](javascript:😉 [#KMP](javascript:😉 [#Android开发](javascript:😉 [#iOS开发](javascript:😉

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 2:56:14

浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析

在技术领域,我们常常被那些闪耀的、可见的成果所吸引。今天,这个焦点无疑是大语言模型技术。它们的流畅对话、惊人的创造力,让我们得以一窥未来的轮廓。然而,作为在企业一线构建、部署和维护复杂系统的实践者,我们深知…

作者头像 李华
网站建设 2026/4/16 2:53:10

Prism九(自动绑定进阶:自定义命名约定与实战技巧)

1. 自动绑定背后的设计哲学 第一次接触Prism的自动绑定功能时,我盯着那个神奇的AutoWireViewModel属性看了好久。这行看似简单的XAML属性背后,其实隐藏着MVVM框架设计的精髓。在传统WPF开发中,我们经常要在XAML里写这样的绑定代码&#xff1a…

作者头像 李华