Best practice when you need two user controls (winforms) to communicate(需要两个用户控件(winforms)进行通信时的最佳实践)
问题描述
Extended problem
I would like to add a new problem in addition to the original problem specified below. One of the user controls in the application contains a list of objects that I need to access from another user control. How can this be done? (I don't believe the division into controls is very well performed, but I'd rather not change it..)
Should I do it by events as with the original problem, or should I get hold of the parent Form, and use it to find the instance of the control, and expose it as a property?
Original problem
I have two user controls in a form that I want to be able to communicate with each other. Usercontrol A should be able to start an operation on B.
What is the preferred way of solving this? Should the form wait for an Event from A, and then start the operation on B? Any design pattern for this? Or is it an even easier solution?
Thanks in advance! :)
The two user controls should not have any knowledge of each other. If you want to always deal with them as a pair, consider creating a third user control to house them.
Should the form wait for an Event from A, and then start the operation on B?
Yes, this is the only good way to handle this.
The extended (bonus?) problem is a bit trickier. I would handle this by having the form pass the user control a delegate to a method on the other user control to retrieve the data. The user control can then invoke the delegate method to call the method on the other control without having any knowledge of its implementation.
这篇关于需要两个用户控件(winforms)进行通信时的最佳实践的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:需要两个用户控件(winforms)进行通信时的最佳实践
基础教程推荐
- 在 VB6 或经典 ASP 中使用 .NET 2022-01-01
- 获取C#保存对话框的文件路径 2022-01-01
- 从 C# 控制相机设备 2022-01-01
- C# 9 新特性——record的相关总结 2023-04-03
- 将数据集转换为列表 2022-01-01
- 重新排序 WPF TabControl 中的选项卡 2022-01-01
- SonarQube C# 分析失败“不是指针的有效行偏移" 2022-01-01
- Mono https webrequest 失败并显示“身份验证或解密失败" 2022-01-01
- 更新 Visual Studio 中的 DataSet 结构以匹配新的 SQL 数据库结构 2022-01-01
- 如果条件可以为空 2022-01-01
