Skillshub swift-swiftui
Standards for State Management, View Lifecycle, and Property Wrappers. Use when managing SwiftUI state, view lifecycle, or property wrappers like @State and @Binding. (triggers: **/*.swift, @State, @Binding, @ObservedObject, View, body)
install
source · Clone the upstream repo
git clone https://github.com/ComeOnOliver/skillshub
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ComeOnOliver/skillshub "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/HoangNguyen0403/agent-skills-standard/swift-swiftui" ~/.claude/skills/comeonoliver-skillshub-swift-swiftui && rm -rf "$T"
manifest:
skills/HoangNguyen0403/agent-skills-standard/swift-swiftui/SKILL.mdsource content
SwiftUI Standards
Priority: P0
Implementation Guidelines
State Management
- @State: @State for data owned by the view (e.g., toggle, text input). Private to the view.
- @Binding: @Binding for data passed down from a parent to a child. Two-way connection.
- @ObservedObject: @ObservedObject when receiving an instance from an external source.
- @StateObject: @StateObject when the view is creating the object instance. View owns lifecycle.
- @EnvironmentObject: inject data into the view's hierarchy via
. Shared across view hierarchy..environmentObject()
View Composition
- Extract Subviews: Keep views small (<200 lines). Extract reusable components.
- View Modifiers: Chain modifiers for styling (
,.font()
)..padding() - Custom Modifiers: Create
for reusable styles.ViewModifier
Performance
- Avoid Heavy Computation: Use
+@State
for async work..task() - Equatable: Conform views to
to prevent unnecessary re-renders.Equatable - LazyStacks: Use
/LazyVStack
when displaying a large number of views in a scrolling container to load them only as they appear.LazyHStack
Anti-Patterns
- No @ObservedObject for owned objects: Use @StateObject.
- No logic in body: Move to computed properties or methods.
- No ! in View: Use if-let or nil coalescing.