当前位置: 首页 > news >正文

深入解析:Flutter 3.38和Dart 3.10中最大的更新

深入解析:Flutter 3.38和Dart 3.10中最大的更新

最近一直在玩鸿蒙,差点落下了Flutter, 这次 Flutter 3.38 和 Dart 3.10 的发布,给我的感觉是:官方终于听到了开发者的心声,开始在“写得爽”这件事上下功夫了。

这次更新不仅有大家馋了很久的 Swift 风格语法糖,还在 Web 和底层架构上动了真格。花了一点时间刷完官方视频和文档,我把最值得关注的几个点提炼出来,聊聊对我们实际开发的各种影响。


Dart 3.10:Dot Shorthands(点简写)—— 终于不用把代码写成“裹脚布”了

这绝对是本次更新的 MVP(最佳功能)。

做 Flutter 的这几年,我最大的槽点之一就是:代码层级深就算了,枚举和常量的名字还贼长。每次写个 CrossAxisAlignment.center,我都觉得自己在复读机。

Dart 3.10 引入的 Dot Shorthands,简单说就是“懂的都懂”。只要编译器能推断出类型,你就可以直接用 . 来搞定。这味道,像极了 Swift,写起来那是相当丝滑。

以前(看完让人想通过):

Column(
// 这种重复写法,写了4年我都写烦了
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Text(
'Hello World',
style: TextStyle.DEFAULT_FONT,
),
],
)

现在(清爽,极度舒适):

Column(
// 编译器知道这里要啥,直接点!
crossAxisAlignment: .center,
children: [
Text(
'Hello World',
style: .DEFAULT_FONT,
),
],
)

这不仅仅是少打几个字的问题,代码的可读性瞬间提升了一个档次。特别是对于嵌套比较深的 UI 代码,视觉干扰少了很多。


Web 开发:终于有个正经的 Config 文件了

如果你和我一样尝试过用 Flutter 写 Web,肯定被那个 flutter run 后面跟的一长串参数折磨过。特别是处理跨域代理(Proxy)的时候,配置起来非常劝退。

在 Flutter 3.38 里,官方终于引入了工程化思维,加了个 webdev config.yml

以前为了解决本地开发跨域,还要自己搭个 Node 代理服务或者改浏览器参数,现在直接在根目录建个 yaml 文件:

# webdev config.yml
server:
port: 8080
# 兄弟们,代理转发终于原生支持了!后端接口随便调
proxy:
/api: http://localhost:3000/api

另外,flutter run -d web-server 模式现在也支持 Hot Reload 了。这意味着我们终于可以用 Chrome 以外的浏览器(比如 Safari)舒服地调试布局了,这对于要在多端兼容的项目来说,简直是救命稻草。


移动端底层:为了性能,Flutter 还是拼

虽然我们平时写 Dart 比较多,但底层的变化往往决定了 App 的上限。这次有两个硬核变动值得老鸟们注意:

  • iOS 侧的 UI Scene 迁移
    苹果的规范越来越严,AppDelegate 那一套旧流程快过时了。Flutter 3.38 加上了对 UI Scene Lifecycle API 的支持。虽然现在是实验性的,但官方提供了迁移命令。
    建议: 手里有维护了一两年的老项目的,近期可以抽空跑一下 flutter config --enable-ui-scene-migration 试试水,别等到苹果强制要求那天抓瞎。

  • Android 侧的 16KB Page Sizes
    为了适配 Android 15+ 和未来的高性能机型,NDK 默认升到了 R28。通俗点说,就是让你的 App 在新手机上内存读写效率更高。这个是如丝般顺滑的升级,基本不需要我们手动干预,坐享其成即可。


架构调整:Material 和 Cupertino 要“分家”了

这是一个信号。官方正在把 Material 和 Cupertino 这两个庞大的 UI 库从 Flutter 核心框架里剥离出去。

这对我这种“长期主义”开发者来说是好事。以前升级 Flutter SDK,最怕的就是 UI 组件行为变了,导致界面崩坏。以后这俩库独立了,核心框架归核心框架,UI 风格归 UI 风格,耦合度降低,包体积(理论上)也会变小。


写在最后

总的来说,Flutter 3.38 + Dart 3.10 这次更新,把“开发体验”提到了很高的优先级

如果你还在观望,建议直接升级 Dart 3.10 尝鲜那个“点简写”语法,真的,一旦用上就回不去了。作为一名 Flutter 老兵,看到它还在不断进化、不断变好,确实挺欣慰的。

关于这次更新,大家有什么想聊的?欢迎在评论区留言,别忘了一键三连

http://www.jsqmd.com/news/149713/

相关文章:

  • 月之暗面Kimi能否运行在TensorFlow框架下?
  • AI芯片初创公司如何接入TensorFlow生态体系
  • 智谱AI GLM系列模型TensorFlow兼容性评估
  • 详细介绍:【JAVA 进阶】深入探秘Netty之Reactor模型:从理论到实战
  • 模型并行实战:TensorFlow Mesh-TensorFlow使用体验
  • P10005 [集训队互测 2023] 基础寄术练习题 题解
  • ChatGLM-TensorFlow适配进展与挑战
  • 澜舟科技孟子模型TensorFlow部署方案
  • 小白也能秒懂:JavaScript 解构赋值的“外挂”人生
  • BeMusic3.1.3音乐网站源码开心版自带中文+搭建教程
  • 基于主从博弈的智能小区电动汽车充电管理与定价策略探索
  • Arduino Nano 33 BLE Sense部署TensorFlow Lite模型
  • 异构计算调度:TensorFlow对CPU/GPU/TPU统一抽象
  • 深度洞察:2025中国家纺十大品牌行业观察与标杆企业巡礼 - 速递信息
  • 探索MATLAB下考虑V2G的光储充一体化微网多目标优化调度策略
  • Apple Silicon M系列芯片上的TensorFlow性能表现
  • TensorFlow与Spark集成:大规模特征处理新范式
  • TensorFlow Hub最新预训练模型排行榜TOP20
  • DSP28035充电桩 量产充电桩 采用DSP28035作为主控 全数字电源设计
  • 昆仑芯PaddlePaddle模型转TensorFlow可行性探讨
  • 基于单片机体温心率脉搏检测仪系统设计
  • 【单片机毕设】151.1基于单片机stm32物联网智能宠物屋控制毕业设计项目
  • 如何整合API测试到自动化流程?
  • WebGL加速TensorFlow.js推理性能实测
  • OpenVINO调用TensorFlow模型性能评测
  • FPGA加速TensorFlow推理:Xilinx Alveo实测
  • XLA编译器优化:提升TensorFlow执行效率的关键
  • 信创环境下TensorFlow兼容性问题及解决方法
  • 构建专属AI芯片编译器:对接TensorFlow Frontend
  • 亲身经历:我用这9款AI工具半天搞定毕业论文,文理医工全覆盖