Flutter基础学习

  1. 核心概念映射

2.Flutter 中 with SingleTickerProviderStateMixin 详解

它是什么:with 是 Dart 的 mixin 语法,类似 Vue 3 的 composable(组合式函数)或 Vue 2 的 mixins,用来给类混入额外的能力。

SingleTickerProviderStateMixin 专门提供一个东西:vsync。

vsync 是什么:Flutter 的动画需要一个"节拍器"来驱动,这个节拍器叫 Ticker。它的作用是每一帧(约 16ms)触发一次回调,驱动动画值从 0 变到 1。

vsync 的意思是"垂直同步"------让动画帧率和屏幕刷新率同步,避免在屏幕不可见时白白消耗 CPU。

SingleTickerProviderStateMixin 让 this 具备了作为 vsync 参数值的资格。

javascript 复制代码
// 需要 vsync 的场景
AnimationController _controller = AnimationController(
  vsync: this,  // ← 这里需要 TickerProvider,mixin 提供了 this 的能力
  duration: const Duration(milliseconds: 300),
);

TabController _tabController = TabController(
  length: 2,
  vsync: this,  // ← 同样需要
);

3.late 关键字详解

Dart 是空安全语言,默认所有变量声明时必须赋初值。late 的意思是:"我保证这个变量在第一次被使用之前一定会被赋值,但现在暂时不赋"。等价于:

Dart 复制代码
// Flutter
late TabController _tabController;

// Vue/TS
let tabController!: TabController  // TS 的非空断言,告诉编译器"我知道我在做什么"
  1. GlobalKey

它的作用是拿到已经存在的子组件的 State 对象的引用,从而调用它的方法。相当于Vue中的Ref

Dart 复制代码
/** <PushDrawerState> 泛型的意思
GlobalKey<PushDrawerState> 里的泛型指定了"我要拿的是哪种 State"。

这样 _drawerKey.currentState 返回的就是 PushDrawerState 类型,你能直接调用它上面定义的 open()、close() 方法,IDE 也有代码提示。

如果不写泛型直接用 GlobalKey(),currentState 返回的是 State 基类,没有 open/close 方法,需要手动强转。
**/
final GlobalKey<PushDrawerState> _drawerKey = GlobalKey<PushDrawerState>();
相关推荐
ZC跨境爬虫1 小时前
跟着 MDN 学 HTML day_17:媒体与 Web Audio API 自动播放指南——策略、检测与最佳实践
前端·笔记·ui·html·音视频·媒体
canonical_entropy1 小时前
Nop Chaos Flux:百度AMIS之后的下一代低代码渲染引擎
前端·低代码·ai编程
时光足迹2 小时前
Tiptap 简单编辑器模版
前端·javascript·react.js
吴声子夜歌2 小时前
Vue3——使用Mock.js
javascript·vue·mock.js
JSLove2 小时前
nginx入门
前端·nginx
时光足迹2 小时前
ThreeJS之GUI控制器
前端·javascript·three.js
时光足迹2 小时前
Tiptap编辑器
前端·javascript·react.js
im_AMBER2 小时前
手撕hot100之矩阵!看完这篇就AC~
javascript·数据结构·线性代数·算法·leetcode·矩阵