likes
comments
collection
share

Flutter Web 的未来,Wasm Native 即将到来

作者站长头像
站长
· 阅读数 17

“第一个围绕 CanvasKit 和 WebAssembly 等新兴 Web 技术进行架构设计的框架。”

如今一年之期将至,最近,Flutter Wasm Native 也迈出了它关键的一个 commit :b8cd317 ,在 master 上 flutter build web --wasm 的支持不再是 Experimental 状态。

Flutter Web 的未来,Wasm Native 即将到来

可以看到,目前 Flutter 和 Dart 已经支持在构建 Web 时添加 WebAssembly 作为编译目标 ,而目前如果要支持 Wasm 的 Flutter 应用,还需要一个支持 WasmGC 的浏览器:

Chromium 和 V8 在 Chromium 119 中发布了对 WasmGC 的 stable 支持, Firefox 在 Firefox 120 中支持 WasmGC (还有点问题),另外 Safari 尚不支持 WasmGC 。

Flutter Web 的未来,Wasm Native 即将到来

有的人可能疑惑, Flutter Web 不是一直都支持编译为 CanvasKit 的 WebAssembly 渲染方式吗?为什么现在又提到 WebAssembly 作为编译目标 ?

这里就不得不说 Dart native , 在此之前, Flutter 对于 WebAssembly 的支持都是:使用 Wasm 来处理CanvasKit 的 runtime,而 Dart 代码会被编译为 JS,而现在,随着 的垃圾收集实现的引入,Dart 已经开始支持直接编译为原生的 Wasm 代码

如果你还无法理解,可以直观对比下面两张图,图1是以前 CanvasKit 的 WebAssembly 渲染方式,图 2 是全新的 Dart native 下的 Wasm 渲染方式,可以看到,其中最大的变化就是 Size 变少了不少,这对于老版 CanvasKit 来说一直是硬伤。

Flutter Web 的未来,Wasm Native 即将到来

Flutter Web 的未来,Wasm Native 即将到来

更小更快更强!

另外随着 Dart 3.3 的发布,目前 Flutter Web 也完成了它之前承诺的一些功能:

Flutter Web 的未来,Wasm Native 即将到来

为了支持 Wasm 编译,Dart 通过 js-interop 改变了与浏览器和 JavaScript API 互操作的方式,这种转变需要 Dart 支持 Wasm 的浏览器 API 来适配:

具体可以查看 dart.dev/interop/js-…dart.dev/interop/js-… 进行迁移

总结一下,虽然 Wasm Native 的支持目前还没普及,但是也决定了 Flutter Web 从「举棋不定」到「落子无悔」的变化,虽然不知道未来 Wasm Native 会怎么样?但是对于 Flutter Web 来说,看到是比现在更好

更多可参考 docs.flutter.dev/platform-in…

转载自:https://juejin.cn/post/7352527589246599178
评论
请登录