您的位置:首页 > 其它

WPF通过委托跨页面修改界面控件,并传值原理完全解析

2017-01-04 17:19 501 查看
网上有很多讲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;
}
}


原理非常简单,就是在页面里面响应外部事件,进而跨页面修改控件或者做点其他事情,有什么不懂的地方,大家可以在下面留言。我看到了会回复
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: