WPF通过委托跨页面修改界面控件,并传值原理完全解析(转)
WPF通过委托跨页面修改界面控件,并传值原理完全解析
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/loongsking/article/details/54021194
网上有很多讲WPF修改控件的,但是大部分都只是代码占据了很大的篇幅,没有详细讲解过程。所以有了我这篇文章。我希望每一个看到这篇文章的朋友都可以看懂,另外不要被太长的标题吓到。
通过委托跨页面修改控件,所谓的原理就是,构造一个可以触发事件A的静态类,然后对页面做出修改的事件B绑定事件A,然后当事件A被触发后,页面里绑定的事件B也被触发响应,于是对页面做出修改。
下面这个图,就是对静态类中的事件A如何触发页面中的事件B,进而跨页面修改界面进行说明的
看了上图想必大家已经明白了。另外进一步的加深了解可以看我自己一个小项目里面的代码。
-
public enum MainPage//切换页面对应的枚举类型
-
{
-
PageMain = 1,
-
PageAdmin,
-
}
-
public class PageChangeArgs : EventArgs//委托参数
-
{
-
private MainPage _currentPage;//这条字段必不可少,因为在构造函数初始化时,属性可能还没有初始化完成,进而造成不可预计的损失
-
public PageChangeArgs(MainPage page)
-
{
-
this._currentPage = page;
-
}
-
-
public MainPage CurrentPage//这个属性就是用来在委托间传递数据的
-
{
-
get { return _currentPage; }
-
set { _currentPage = value; }
-
}
-
-
}
-
public static class MainWindowsChange
-
{
-
public static event EventHandler<PageChangeArgs> pageChangeEvent;//定义在MainWindowsChange中的一个事件,参数是PageChangeArgs对象
-
-
public static void PageChange(MainPage pageValue)
-
{
-
var pageChangeArgs = new PageChangeArgs(pageValue);
-
if (pageChangeEvent != null)//如果MainWindowsChange构造函数中给pageChangeEvent注册了函数就不为null
-
{
-
pageChangeEvent(null, pageChangeArgs);//触发事件,执行所有注册过的函数
-
}
-
}
-
}
下面是MainWindow里面的代码
-
public partial class MainWindow : Window
-
{
-
Dictionary<MainPage, Page> pageList;
-
public MainWindow()
-
{
-
InitializeComponent();
-
frameMain.Content = new PageMain();
-
-
pageList = new Dictionary<MainPage, Page>
-
{
-
{ MainPage.PageMain, new PageMain() },
-
{ MainPage.PageAdmin, new PageAdmin()},
-
};
-
-
MainWindowsChange.pageChangeEvent += ChangeFramePage;
-
}
-
public void ChangeFramePage(Object sender, PageChangeArgs page)
-
{
-
frameMain.Content = pageList.Single(h=> h.Key == page.CurrentPage).Value;
-
}
-
}
原理非常简单,就是在页面里面响应外部事件,进而跨页面修改控件或者做点其他事情,有什么不懂的地方,大家可以在下面留言。我看到了会回复