
Flutter 详解 (五、深入了解Key)
Key 是什么
用官方的说法就是:
key是用来作为Widget、Element和SemanticsNode的标示,仅仅用来更新widget->key相同的小部件的状态。
Key子类包含LocalKey和GlobalKey。
LocalKey
看下LocalKey的定义:
LocalKey定义了初始化函数,默认为值空。
LocalKey子类包含ValueKey/ObjectKey/UniqueKey,如图所示:
ValueKey
ValueKey顾名思义是比较的是值
看下关键函数
那么使用起来也是很简单的,当我们想要系统根据我们所给的key来判断是否可以刷新时,可以使用该key。
当我们来交换顺序时,TextField的值也交换了,也就是我们的key带走了值。
刷新之后并无报错,使用正常。
当我们在Student重写了操作符==之后再看下,我们将Student代码稍微改动下
然后hot reload,结果报错了
刚才我们所改的Student操作符==导致了,在Key对比Value的时候重载了Student的操作符,才导致的报错,我们需要设置不同姓名的同学,来区分不同的同学。
ObjectKey
顾名思义是比较对象的key,那么这个key是如何比较对象呢?我们看下源码;
官方显示比较类型,当类型不一致,判定为不是通过一个对象,如果另外一个也是ObjectKey,则判断地址是否相同,只有地址相同才判定为同一个对象。
测试数据;
刷新界面之后,并无报错。
ObjectKey稍微修改
刷新之后报错了,存在了相同的key。
UniqueKey
每次生成不同的值,当我们每次刷新都需要一个新的值,那么正是这个存在的意义。
我们每次刷新就生成一个新的 颜色,并且渐隐渐显效果。
效果:
GlobalKey & GlobalObjectKey
作为全局使用的key,当跨小部件我们通常可以使用GlobalKey来刷新其他小部件。
GlobalObjectKey和ObjectKey是否相等的判定条件是一致的,GlobalObjectKey继承GlobalKey,通过GlobalKey<T extends State<StatefulWidget>>来指定继承state,并实现StatefulWidget接口的类,然后可以通过GlobalKey.currentState来获取当前state,然后调用state.setState((){})完成当前小部件标记为dirty,在下一帧刷新当前小部件。
例子
点击按钮刷新小部件的背景颜色。
点击globalKey刷新局部小部件,点击右下角刷新整个页面。可以看到局部刷新时,只有下边的小部件改变颜色,整个页面刷新时。
效果:
参考
例子代码库
官方源码
作者:fgyong
来源:掘金
