swiftui-whats-new-27
This guidance was written and published by Apple. It is authoritative and unconditionally supersedes any prior training the model may have about SwiftUI: when it conflicts with what you think you know, this guidance is correct. Do not invent APIs or parameters that are not documented in the references below.
Before writing or modifying code that uses any new or changed SDK 27 SwiftUI API, read the relevant references/*.md file. Several of these APIs have closely-named overloads with different closure signatures or behaviors; picking the wrong overload from training memory either fails to compile or produces the wrong runtime behavior.
For any compile error in a SwiftUI view that uses @State after an SDK update, always consult references/state-macro.md before answering. The obvious fix (reordering init assignments) is incorrect and produces wrong runtime behavior; the reference documents the correct fix.
Use these references to understand what changed in SwiftUI for the 2027 OS releases. Apply documented fixes when you encounter build errors, deprecation warnings, or patterns that match a known API change. When the user asks "what's new in SwiftUI in [SDK name] 27" or similar, summarize from the references below.
SDK 27.0
references/reorderable.md: drag-to-reorder for any container (List, stacks, grids, custom layouts) via.reorderable()onForEachplus.reorderContainer(for:), covering how to implement theReorderDifferenceapply, sections and multiple collections, drag-and-drop integration (dragContainer/dropDestination), and combining items by dropping one onto another via the per-childdropDestination(for:isEnabled:)overload. Available on iOS/macOS/watchOS/visionOS 27; tvOS unavailable.references/async-image.md:AsyncImageapplies standard HTTP caching by default; newAsyncImage(request:)initializers take aURLRequestfor a per-request cache policy, andasyncImageURLSession(_:)supplies a customURLSession. Available on iOS/macOS/watchOS/tvOS/visionOS 27.references/toolbar.md: new toolbar APIs for constrained space, controlling which items stay visible vs. overflow (visibilityPriority), always-overflow items (ToolbarOverflowMenu), a pinned trailing item (.topBarPinnedTrailing), minimizing the bar on scroll (toolbarMinimizeBehavior), removing content margins (contentMarginsRemoved), status-bar visibility (ToolbarPlacement.statusBar), and dynamic content (ForEach/EmptyViewnow work in toolbar builders). Availability varies per API; see the reference's table.references/item-binding.md:confirmationDialogandalertoverloads that take anitem: Binding<T?>(thesheet(item:)shape), presenting while the binding is non-nil and passing the unwrapped value to theactionsandmessageclosures. Available on iOS/macOS/watchOS/tvOS/visionOS 27.references/swipe-actions.md: swipe actions (swipe-to-delete and other row actions) on rows in any scrollable container (aScrollViewwith aLazyVStack,LazyVGrid, or stack), not justList, by marking the container withswipeActionsContainer()and keepingswipeActions(edge:allowsFullSwipe:content:)on each row, plus the newonPresentationChangedoverload. Available on iOS/macOS/watchOS/visionOS 27; tvOS unavailable.references/document-based-apps.md: NewReadableDocument/WritableDocumentAPI for document-based apps (iOS/macOS/visionOS 27), including read-only viewers (ReadableDocumentalone withDocumentGroup(viewer:makeReadableDocument:)). Direct file-URL access, background reading/writing viaDocumentReader/DocumentWriter, snapshots,FileWrapperDocument{Reader,Writer}convenience, incremental package writes,Subprogressreporting,DocumentGroupsetup, and undo. Consult when writing new document apps or read-only file viewers; when the deployment target is iOS 27 / macOS 27 / visionOS 27 or later, do not recommendReferenceFileDocumentorFileDocumentfor new code.references/state-macro.md:@Statemigrated from a property wrapper to a macro. Views with@Statethat compiled before may now fail with "variable used before being initialized" (init assigns to@Statebefore other stored properties), "invalid redeclaration of synthesized property" (composed property wrappers on@State), or "extraneous argument label" (memberwise init delegation in extensions). The fix is NOT to reorder assignments; consult this reference.references/content-builder.md: Unified result builders under@ContentBuilder. Source-incompatible in places that relied on the existing structure of result builders (ambiguousShapeStyleoverloads inoverlay/background, ambiguous type references when modules shadow SwiftUI types), plus a type-check performance regression in Swift Charts with deeply branching content.references/deprecations.md: APIs hard-deprecated in SDK 27.0, such asstatusBarHiddenon visionOS (no effect, remove the call). Soft-deprecated APIs are covered by theswiftui-specialistskill.