应用退出时自动保存数据,是 Avalonia 桌面应用提升用户体验的关键一环。核心思路是:在窗口关闭或应用退出前,把当前 ViewModel 中的关键状态(如列表、设置、窗口尺寸等)序列化到本地文件或配置存储中;启动时再反序列化加载回来。
监听窗口关闭事件并触发保存
最直接的方式是在主窗口的
Closing事件中执行保存逻辑。推荐在 ViewModel 层统一处理,避免 UI 层耦合业务逻辑: 在 ViewModel 中定义一个
SaveStateAsync()方法,负责将数据(如
IEnumerable<todoitem></todoitem>)写入 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<apppersistentstate>()</apppersistentstate>加载 在退出前调用
RxApp.SuspensionHost.SaveStateAsync(new AppPersistentState { ... })
底层默认使用 LocalStorage(即
LocalSettings或平台特定目录),无需手动管理路径
文件存储路径建议与容错处理
保存路径应跨平台一致且用户友好:
优先使用Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData),Windows/macOS/Linux 均兼容 避免硬编码桌面路径(如示例中的
Desktop/Avalonia/...),除非明确面向终端用户调试场景 读取时用
try/catch捕获
FileNotFoundException,返回空数据或默认值,不中断启动流程 写入前确保目录存在:
Directory.CreateDirectory(Path.GetDirectoryName(filePath))
