解决.NET程序中同一按钮单击事件中多次刷新Label时只有最后一次赋值生效的问题...

Winform更新UI技巧
本文介绍了一个Winform应用程序中更新UI的问题及解决方案。通过在按钮点击事件中更改Label文本并调用Refresh方法,实现了在长时间操作过程中正确显示临时状态。

简单描述一下问题,即我建立了一个Winform工程,有一个窗体FormMain,其中有一个Label(lblTest)和一个Button(btnRefreshLabel),如下图所示:

其中单击按钮后会执行以下代码:

private void btnRefreshLabel_Click(object sender, EventArgs e)
{
    this.lblTest.Text = "加载中……\n" + DateTime.Now.ToString();
    System.Threading.Thread.Sleep(3000);
    this.lblTest.Text = "加载完毕\n" + DateTime.Now.ToString();
}

先更新Label的文字到“加载中”,执行完一段3000毫秒的代码后,将Label的文字设置为“加载完毕”。不过这样写有一个问题,就是这段代码中的“加载中”永远也不会显示出来,点击按钮后,屏幕会卡死3秒钟,然后直接刷出“加载完毕”。后来研究了下,这个问题的解决方法就是在每次更新Label的内容后立即执行一次Refresh函数:

private void btnRefreshLabel_Click(object sender, EventArgs e)
{
    this.lblTest.Text = "加载中……\n" + DateTime.Now.ToString();
    this.Refresh(); //添加了这句话
    System.Threading.Thread.Sleep(3000);
    this.lblTest.Text = "加载完毕\n" + DateTime.Now.ToString();
}

程序运行截图如下:

1)单击按钮后,Label显示“加载中”。

2)三秒后,Label显示“加载完毕”。

END

转载于:https://my.oschina.net/Tsybius2014/blog/707808

在Windows Forms的TreeView控件中,防止同一节点多次点击导致重复执行逻辑,可以采用以下策略: 1. **事件委托缓存**: - 在节点单击事件的处理函数内部,创建一个静态字段来保存当前正在处理的节点引用。每次事件发生,检查这个字段是否指向同一个节点,如果是,则忽略本次事件。 ```csharp private TreeNode _currentProcessingNode; private void treeView1_AfterSelect(object sender, TreeViewEventArgs e) { if (_currentProcessingNode == e.Node) return; _currentProcessingNode = e.Node; // 正常处理点击逻辑... _currentProcessingNode = null; } ``` 2. **事件处理逻辑更新**: - 将事件处理逻辑封装到一个独立的方法中,并在开始处理前检查是否有上一次处理记录。如果没有,才开始处理。 ```csharp private void ProcessTreeNode(TreeNode node) { if (!_processedNodes.Contains(node)) { _processedNodes.Add(node); // 正常处理点击逻辑... } } private List<TreeNode> _processedNodes = new List<TreeNode>(); private void treeView1_AfterSelect(object sender, TreeViewEventArgs e) { ProcessTreeNode(e.Node); } ``` 3. **禁用重复点击**: - 使用锁定机制,当某个节点被选中,暂禁用其自身以及所有子节点的点击事件。 ```csharp private bool _processing = false; private void treeView1_AfterSelect(object sender, TreeViewEventArgs e) { if (_processing) return; _processing = true; try { // 处理点击逻辑... } finally { _processing = false; } } ``` 4. **取消按钮或确认提示**: - 提供一个确认或者取消按钮,让用户确认是否真的想再次执行操作。 以上方法可以根据实际需求选择合适的方式。记住,关键在于在处理点击事件,始终跟踪上次执行的操作以便于判断是否应该继续执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值