应用退出时自动保存数据需在Closing事件或ShutdownRequested钩子中调用ViewModel的SaveStateAsync()方法,结合ReactiveUI SuspensionHost可声明式管理状态,存储路径推荐使用ApplicationData目录并做好异常容错。

应用退出时自动保存数据,是 Avalonia 桌面应用提升用户体验的关键一环。核心思路是:在窗口关闭或应用退出前,把当前 ViewModel 中的关键状态(如列表、设置、窗口尺寸等)序列化到本地文件或配置存储中;启动时再反序列化加载回来。
监听窗口关闭事件并触发保存
最直接的方式是在主窗口的 Closing 事件中执行保存逻辑。推荐在 ViewModel 层统一处理,避免 UI 层耦合业务逻辑:
- 在 ViewModel 中定义一个
SaveStateAsync()方法,负责将数据(如IEnumerable)写入 JSON 文件 - 在 View 的代码后台(如
MainWindow.axaml.cs)中订阅Closing事件,并调用 ViewModel 的保存方法 - 注意:需 同步等待保存完成,避免应用提前退出导致写入中断(可用
await SaveStateAsync().ConfigureAwait(false))
利用 Avalonia 生命周期钩子统一管理
Avalonia 提供了标准生命周期入口点,适合集中处理退出前的清理与持久化:
- 在
App.axaml.cs的OnFrameworkInitializationCompleted中,为IClassicDesktopStyleApplicationLifetime的ShutdownRequested事件添加处理 - 该事件在用户点击关闭、调用
Application.Shutdown()或系统注销时触发,比单个窗口的Closing更全面 - 可在其中遍历所有活跃 ViewModel 并调用其
Save()方法,或统一调用一个StateService.SaveAllAsync()
结合 ReactiveUI SuspensionHost 管理应用级状态
若项目已集成 ReactiveUI,可使用 RxApp.SuspensionHost 实现声明式状态存取:
- 定义强类型状态类(如
AppPersistentState),包含窗口位置、主题偏好、最近打开文件等字段 - 在应用启动时调用
RxApp.SuspensionHost.GetAppState加载() - 在退出前调用
RxApp.SuspensionHost.SaveStateAsync(new AppPersistentState { ... }) - 底层默认使用
LocalStorage(即LocalSettings或平台特定目录),无需手动管理路径
文件存储路径建议与容错处理
保存路径应跨平台一致且用户友好:










