Flutter Web 的未来,Wasm Native 即将到来
“第一个围绕 CanvasKit 和 WebAssembly 等新兴 Web 技术进行架构设计的框架。”
如今一年之期将至,最近,Flutter Wasm Native 也迈出了它关键的一个 commit :b8cd317 ,在 master 上 flutter build web --wasm
的支持不再是 Experimental 状态。
可以看到,目前 Flutter 和 Dart 已经支持在构建 Web 时添加 WebAssembly 作为编译目标 ,而目前如果要支持 Wasm 的 Flutter 应用,还需要一个支持 WasmGC 的浏览器:
Chromium 和 V8 在 Chromium 119 中发布了对 WasmGC 的 stable 支持, Firefox 在 Firefox 120 中支持 WasmGC (还有点问题),另外 Safari 尚不支持 WasmGC 。
有的人可能疑惑, 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
来说一直是硬伤。
更小更快更强!
另外随着 Dart 3.3 的发布,目前 Flutter Web 也完成了它之前承诺的一些功能:
为了支持 Wasm 编译,Dart 通过 js-interop 改变了与浏览器和 JavaScript API 互操作的方式,这种转变需要 Dart 支持 Wasm 的浏览器 API 来适配:
package:web
,取代dart:html
(和其他网络库)dart:js_interop
, 取代package:js
和dart:js
具体可以查看 dart.dev/interop/js-… 和 dart.dev/interop/js-… 进行迁移
总结一下,虽然 Wasm Native 的支持目前还没普及,但是也决定了 Flutter Web 从「举棋不定」到「落子无悔」的变化,虽然不知道未来 Wasm Native 会怎么样?但是对于 Flutter Web 来说,看到是比现在更好。
转载自:https://juejin.cn/post/7352527589246599178