Avalonia复用.NET标准HttpClient,需单例管理、异步请求并更新ViewModel属性触发UI刷新,注意错误处理、取消令牌及线程安全。

Avalonia 本身不提供专门的 HTTP 客户端,它复用 .NET 标准的 HttpClient —— 和 WinForms、WPF、控制台程序完全一样。你不需要 Avalonia 特有的“网络组件”,直接用 System.Net.Http.HttpClient 即可,但要注意线程上下文和 UI 更新的安全性。
基础用法:创建并复用 HttpClient 实例
别在每次请求时 new HttpClient() —— 这容易引发端口耗尽和 DNS 缓存问题。推荐用单例或 DI 注入方式管理:
- 在
Program.cs或App.xaml.cs中注册为单例(使用 Avalonia 的 DI 容器):
然后在 ViewModel 或页面中通过构造函数注入使用:
public class MainViewModel(HttpClient client) { ... }发起 GET 请求并更新 UI
Avalonia 是基于绑定的 UI 框架,网络请求必须在后台线程执行,结果返回后才能安全更新 ViewModel 属性(触发 UI 刷新)。推荐用 async/await + NotifyPropertyChanged 模式:
标签: js json app 端口 ai win dns 状态码 c# .net
还木有评论哦,快来抢沙发吧~