首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >未更新TableLayout的Eto.Forms async命令已执行处理程序

未更新TableLayout的Eto.Forms async命令已执行处理程序
EN

Stack Overflow用户
提问于 2019-10-09 02:30:27
回答 1查看 84关注 0票数 0

我正在为一个简单的C#应用程序使用Eto.Forms。当一个按钮被点击时,我想从一个API中获取一些数据(使用Net.Http.HttpClient,它已经工作得很好了),等待响应,并更新TableLayout中的一些信息。

我已经尝试了以下代码。调用了RefreshClicked方法,调试输出打印出我期望的结果(应该插入到表中的数据),但是表没有任何变化。还值得注意的是,从方法内部调用DataTable.Rows.Clear()确实清除了表。

如果我将相同的代码从方法内部复制并粘贴到构造函数中,并使用一些数据进行测试,它会像我预期的那样工作(将其插入到表中),但不是在这个方法中。

代码语言:javascript
复制
// inside my class
private TableLayout DataTable = new TableLayout();
private async void RefreshClicked(object sender, EventArgs e)
{
    var results = await GetDataFromApi();

    foreach (Result result in results)
    {
        Console.Out.WriteLine(/* results for debugging purposes */);
        DataTable.Rows.Add(new TableRow(/* info from results */));
    }
}
代码语言:javascript
复制
// inside my constructor
Content = DataTable;

var Refresh = new Command
{
    // ...
};

Refresh.Executed += RefreshClicked;

没有任何错误消息,只是没有更新表。任何帮助都将不胜感激。

编辑:

添加行后调用DataTable.Update()不执行任何操作。

EN

回答 1

Stack Overflow用户

发布于 2021-06-10 00:15:24

我相信你需要调用这个方法:http://pages.picoe.ca/docs/api/html/M_Eto_Forms_Application_Invoke.htm

将行添加和更新放在Action

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58292137

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档