View in English

  • Apple 开发者
    • 入门汇总

    探索“入门汇总”

    • 概览
    • 学习
    • Apple Developer Program

    及时了解最新动态

    • 最新动态
    • 开发者你好
    • 平台

    探索“平台”

    • Apple 平台
    • iOS
    • iPadOS
    • macOS
    • Apple tvOS
    • visionOS
    • watchOS
    • App Store

    精选

    • 设计
    • 分发
    • 游戏
    • 配件
    • 网页
    • Home
    • CarPlay 车载
    • 技术

    探索“技术”

    • 概览
    • Xcode
    • Swift
    • SwiftUI

    精选

    • 辅助功能
    • App Intents
    • Apple 智能
    • 游戏
    • 机器学习与 AI
    • 安全性
    • Xcode Cloud
    • 社区

    探索“社区”

    • 概览
    • “与 Apple 会面交流”活动
    • 社区主导的活动
    • 开发者论坛
    • 开源

    精选

    • WWDC
    • Swift Student Challenge
    • 开发者故事
    • App Store 大奖
    • Apple 设计大奖
    • Apple Developer Centers
    • 文档

    探索“文档”

    • 文档库
    • 技术概述
    • 示例代码
    • 《人机界面指南》
    • 视频

    发布说明

    • 精选更新
    • iOS
    • iPadOS
    • macOS
    • watchOS
    • visionOS
    • Apple tvOS
    • Xcode
    • 下载

    探索“下载”

    • 所有下载
    • 操作系统
    • 应用程序
    • 设计资源

    精选

    • Xcode
    • TestFlight
    • 字体
    • SF Symbols
    • Icon Composer
    • 支持

    探索“支持”

    • 概览
    • 帮助指南
    • 开发者论坛
    • “反馈助理”
    • 联系我们

    精选

    • 《开发者账户帮助》
    • 《App 审核指南》
    • 《App Store Connect 帮助》
    • 即将实行的要求
    • 协议和准则
    • 系统状态
  • 快速链接

    • 活动
    • 新闻
    • 论坛
    • 示例代码
    • 视频
 

视频

打开菜单 关闭菜单
  • 专题
  • 所有视频
  • 关于

更多视频

  • 简介
  • 概要
  • 代码
  • SwiftData 的新功能

    了解 SwiftData 的最新增强功能。我们将介绍如何使用 Codable 持久保留自定类型和第三方类型的数据,并将获取的数据分组到 SwiftUI App 的各个分区。我们还将探索如何使用 ModelResultsObserver 和 HistoryObserver 在其他各处观察数据存储的变化,以便灵活地驱动强大的状态对象、与基于委托的架构实现整合,并精准地响应模型更新。

    章节

    • 0:00 - Introduction
    • 0:53 - Sectioning your fetches
    • 2:56 - Using custom types
    • 6:26 - Observing data stores with ResultsObserver
    • 9:41 - Observing history with HistoryObserver
    • 12:20 - Next steps

    资源

    • SwiftData
    • Adopting SwiftData for a Core Data app
      • 高清视频
      • 标清视频

    相关视频

    WWDC26

    • 跟随编程:使用 SwiftData 添加持久化功能

    WWDC24

    • 使用 SwiftData 历史记录 API 跟踪模型更改
  • 搜索此视频…
    • 0:01 - Sectioned fetching

      // Sectioned fetching
      
      struct TripListView: View {   
          @Query(sort: \Trip.startDate,
                 sectionBy: \.destination)
          var trips: [Trip]
      
          var body: some View: {
              List(selection: $selection) {
                  ForEach(_trips.sections) {section in
                      Section(section.id) {
                          ForEach(trips) {trip in
                              TripListItem(trip: trip)
                          }
                     }
                  }
              }
          }
      }
    • 4:59 - Using Codable

      // Using Codable
      
      import SwiftData
      
      @Model class Trip {
      
          struct Location: Codable {
              var latitude: Double
              var longitude: Double
          }
      
          var name: String
          var destination: String
      
          var startDate: Date
          var endDate: Date
      
          var location: Location?
          @Attribute(.codable) var mapItemIdentifier: MKMapItem.Identifier?
      }
    • 8:20 - // Use observation to update map bounds

      // Use observation to update map bounds
      
      @Observable @MainActor final class MapCameraController {
          private let modelResultsObserver: ModelResultsObserver<Trip>
          var bounds: MapCameraBounds?
          private var token: ObservationTracking.Token?
      
          init(modelContext: ModelContext) throws {
              modelResultsObserver = try ModelResultsObserver<Trip>(modelContext: modelContext)
      
              token = withContinuousObservation(options: [.didSet]) {[weak self], event in
                  self?.bounds = self?.calculateBounds(trips: modelResultsObserver.results)
             }
          }
      
          private func calculateBounds(trips: [Trip]) -> MapCameraBounds? { / * */ }
      }
    • 8:21 - // Using HistoryObserver to sync with a server

      // Using HistoryObserver to sync with a server
      
      @SyncActor final class ServerSync {
          private let observer: HistoryObserver
          private var token: ObservationTracking.Token?
      
          func start() throws {
              self.observer = try HistoryObserver(authors: ["App"], modelContainer: modelContainer)
              token = withContinuousObservation(options: .didSet) {[weak self] _ in
                  _ = self?.observer.eventCounter
                  self?.processChanges()
              }
          }
      
          private func processChanges() {
              // Fetch and process history transactions
          }
      }
    • 0:00 - Introduction
    • What's new in SwiftData for Apple's 2027 releases, with a preview of the agenda: sectioning fetches, using custom types, and observing data stores.

    • 0:53 - Sectioning your fetches
    • Use @Query's new sectionBy: parameter to group results by a key path. Access the underlying query via the underscore-prefixed name to iterate sections, each with an id and a collection of models — demonstrated by grouping trips by destination in SampleTrips.

    • 2:56 - Using custom types
    • Store types SwiftData can't model natively — like MKMapItem.Identifier — by marking properties with @Attribute(.codable). Treat codable as an escape hatch for external types, not types you own; modeling your own types as @Model or supported value types unlocks filtering, sorting, and migration.

    • 6:26 - Observing data stores with ResultsObserver
    • The new ResultsObserver brings Query-style fetching to non-SwiftUI code. Combine it with withContinuousObservation(didSet:) to react to model changes anywhere in your app — shown updating map camera bounds as trips change.

    • 9:41 - Observing history with HistoryObserver
    • HistoryObserver exposes a single observable eventCounter that ticks when new persistent-history transactions arrive. Pair it with ModelContext.fetchHistory() to filter by model type or transaction author — ideal for syncing changes to an external server.

    • 12:20 - Next steps
    • Recap: section your fetches, adopt codable types, react to data changes with ResultsObserver, and observe history with HistoryObserver.

Developer Footer

  • 视频
  • WWDC26
  • SwiftData 的新功能
  • 打开菜单 关闭菜单
    • iOS
    • iPadOS
    • macOS
    • Apple tvOS
    • visionOS
    • watchOS
    打开菜单 关闭菜单
    • Swift
    • SwiftUI
    • Swift Playground
    • TestFlight
    • Xcode
    • Xcode Cloud
    • SF Symbols
    打开菜单 关闭菜单
    • 辅助功能
    • 配件
    • Apple 智能
    • App 扩展
    • App Store
    • 音频与视频 (英文)
    • 增强现实
    • 设计
    • 分发
    • 教育
    • 字体 (英文)
    • 游戏
    • 健康与健身
    • App 内购买项目
    • 本地化
    • 地图与位置
    • 机器学习与 AI
    • 开源资源 (英文)
    • 安全性
    • Safari 浏览器与网页 (英文)
    打开菜单 关闭菜单
    • 完整文档 (英文)
    • 部分主题文档 (简体中文)
    • 教程
    • 下载
    • 论坛 (英文)
    • 视频
    打开菜单 关闭菜单
    • 支持文档
    • 联系我们
    • 错误报告
    • 系统状态 (英文)
    打开菜单 关闭菜单
    • Apple 开发者
    • App Store Connect
    • 证书、标识符和描述文件 (英文)
    • 反馈助理
    打开菜单 关闭菜单
    • Apple Developer Program
    • Apple Developer Enterprise Program
    • App Store Small Business Program
    • MFi Program (英文)
    • Mini Apps Partner Program
    • News Partner Program (英文)
    • Video Partner Program (英文)
    • 安全赏金计划 (英文)
    • Security Research Device Program (英文)
    打开菜单 关闭菜单
    • 与 Apple 会面交流
    • Apple Developer Center
    • App Store 大奖 (英文)
    • Apple 设计大奖
    • Apple Developer Academies (英文)
    • WWDC
    阅读最近新闻。
    获取 Apple Developer App。
    版权所有 © 2026 Apple Inc. 保留所有权利。
    使用条款 隐私政策 协议和准则