首页 > 作文

C# CM框架实现多页面管理的实例代码

更新时间:2023-04-06 03:40:33 阅读: 评论:0

概述

之前我分享过一个wpf的项目实践,主页面左侧是个listbox,每次选择改变后呈现对应的页面,界面图如下

要实现这样一个功能,我之前是采用传统方式实现的,本节我采用cm框架下的conductor<t>去实现,这样代码量可以大幅度压缩,核心代码就一行。

传统方式

后台代码:①定义集合并添加数据:

public iviewmodel activewindowview { get; t; }       public obrvablecollection<string> listboxitems { get; t; }       public string lecteditem { get; t; }
listboxitems = new obrvablecollection<string>() { };           listboxitems.add("shellview");           listboxitems.add("eventaggregatorview");           listboxitems.add("conductorview");           listboxitems.add("matchtemplateview");           listboxitems.add("indicatorlightview");           listboxitems.add("memorandumview"中医学院全国排名);           listboxitems.add("ftptestview");

  ②listbox选择改变后切换页面:

public void listboxitems_lectionchanged()       {          s多边形外角和witch(lecteditem)           {               ca "shellview":                   activewindowview = new shellviewmodel();break;               ca "eventaggregatorview":                      中秋搞笑祝福短信大全 activewindowview = eventaggregatorviewmodel.instance; break;               ca "conductorview":                   activewindowview = new conductorviewmodel(); break;               ca "matchtemplateview":                   activewindowview = new matchtemplateviewmodel(); break;               ca "indicatorlightview":                   activewindowview = new indicatorlightviewmodel(); break;               ca "memorandumview":                   activewindowview = ioc.get<memorandumviewmodel>(); break;               ca "ftptestview":                   activewindowview = new ftptestviewmodel(new ftpconfig()); break;               default:break;           }       }

  ③前台绑定:

<listbox name="listboxitems" grid.column="0" lecteditem="{binding lecteditem}" margin="2"                 cal:message.attach="[event lectionchanged] = [action listboxitems_lectionchanged]"/>            <contentcontrol name="activewindowview"/>

利用cm框架下conductor<t>实现

① 后台代码:首先是需要继承conductor<iviewmodel>.collection.oneactive这样才能使用这个类下面的方法和属性,其次是构造函数需要添加接收的接口ienumerable<t>,这样改造完代码如下:

public mainwindowviewmodel(ienumerable<iviewmodel> modules)      {   嚣张个性签名       items.addrange(modules);          activateitem(items.firstordefault(vm => vm.gettype() ==typeof(indicatorlightviewmodel)));      }

  如果不考虑首次激活的页面那核心代码就只有一句:

items.addrange(modules);

②前台代码:

<listbox name="items" grid.column="0"  margin="2" displaymemberpath="displayname"/> 360手机助手怎么卸载<contentcontrol name="activeitem"/>

这样前后台就设置完事了,继承了一个框架的多屏幕管理类,使得前后台代码大幅度精简,功能上也没打折扣,准确说是更强大了,这就是cm框架的优势所在。

到此这篇关于c#cm框架下一行代码实现多页面管理的文章就介绍到这了,更多相关c#cm框架多页面管理内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

本文发布于:2023-04-06 03:40:32,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/38a61e50d9821080cc84a85ed7c67890.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:C# CM框架实现多页面管理的实例代码.doc

本文 PDF 下载地址:C# CM框架实现多页面管理的实例代码.pdf

标签:代码   框架   后台   页面
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图