> ios-state-management

Standards for Combine, Observation, and Reactive Programming. Use when managing state with Combine, @Observable, or reactive patterns in iOS. (triggers: **/*.swift, Observable, @Published, PassthroughSubject, @Observable, @Namespace)

fetch
$curl "https://skillshub.wtf/HoangNguyen0403/agent-skills-standard/ios-state-management?format=md"
SKILL.mdios-state-management

iOS State Management Standards

Priority: P0

Implementation Guidelines

Combine (Reactive)

  • Publishers: Use @Published for state in ViewModels. Use PassthroughSubject for one-time events (Transitions/Alerts).
  • Memory Management: Store subscriptions in a Set<AnyCancellable>. Ensure they are cleared on deinit.
  • Operators: Use operators like .debounce, .filter, .map, and .flatMap to transform input stream.
  • Schedulers: Always prefix UI property updates with @MainActor or use .receive(on: DispatchQueue.main).

Observation Framework (iOS 17+)

  • @Observable: Use for modern, macro-based observation. Replace ObservableObject in SwiftUI apps.
  • Binding: Use $state for two-way bindings in SwiftUI. No boilerplate objectWillChange calls.

Best Practices

  • ViewState Unification: Prefer a single State enum or struct (Unidirectional) for complex screens.
  • Avoid Over-Reactive: Don't use Combine for simple local flags. Use standard @State or variables.

Anti-Patterns

  • Subscription Leaks: **No uncleared subscriptions**: Always use .store(in: &cancellables).
  • Main Thread Violation: **No UI updates on Background**: Use .receive(on: .main).
  • Manual objectWillChange: **No manual notifications**: Use @Published or @Observable.

References

┌ stats

installs/wk0
░░░░░░░░░░
github stars341
██████████
first seenMar 17, 2026
└────────────

┌ repo

HoangNguyen0403/agent-skills-standard
by HoangNguyen0403
└────────────

┌ tags

└────────────