zl程序教程

您现在的位置是:首页 >  其他

当前栏目

SwiftUI 高级用法之如何捕获截取事件实现隐藏收起展开PreferenceKey(教程含源码)

事件源码教程 实现 如何 用法 高级 隐藏
2023-09-11 14:18:30 时间

实战需求

SwiftUI 高级用法之如何捕获截取事件实现隐藏收起展开

本文价值与收获

看完本文后,您将能够作出下面的界面

截屏2021-01-13 上午9.23.52.png


基础知识

SwiftUI提供了PreferenceKeys的功能,这是SwiftUI通过视图树传递信息的方式。PreferenceKey 是一种通用协议,需要一个静态函数和一个静态默认值:

struct SizePreferenceKey: PreferenceKey {
  static var defaultValue: CGSize = .zero
  static func reduce(value: inout CGSize, nextValue: () -> CGSize) {}
}
  • defaultValue 是当视图对此键没有显式值时使用的值
  • reduce(value:nextValue:) 将树中找到的键值与新的键值相结合

PreferenceKey示例,存储孩子的实际尺寸:

var body: some View {
  childView
    .background(
      GeometryReader { geometryProxy in
        Color.clear
          .preference(key: SizePreferenceKey.self, value: geometryProxy.size)
      }
    )
}