MVVM模式应用 之为ApplicationBarIconButton 添加Command操作属性
在学习MVVM的过程中,总是会遇到挫折,一碰到就是花费好长时间去解决。。唉,不求量,只求质。
第一种(已经实践成功):
(1)http://bindableapplicationb.codeplex.com/ 去这个网址,下载项目吧。
接下来,我就需要在我的项目中添加命名空间了。
添加代码:
<bar:Bindable.ApplicationBar> <bar:BindableApplicationBar> <bar:BindableApplicationBarButton Text="添加大学" IconUri="Images/appbar.add.rest.png"/> </bar:BindableApplicationBar> </bar:Bindable.ApplicationBar>
先看看效果:
看到了吧。。和ApplicationBarIconButton的效果是一样的。
而且,还有ApplicationBarIconButton不能实现的东西。
<bar:Bindable.ApplicationBar> <bar:BindableApplicationBar> <bar:BindableApplicationBarButton Text="添加大学" IconUri="Images/appbar.add.rest.png" Command="{Binding ToAddPageCommand}"/> </bar:BindableApplicationBar> </bar:Bindable.ApplicationBar>
看到没有啊 。。。
然后,在MainViewModel.CS中添加如下代码
(1)添加以下属性和方法:
public RelayCommand ToAddPageCommand { get; set; } public void NavigateToAddUniversity() { University1 = University3; }
(2)在初始化函数MainViewModel()中添加一句:
ToAddPageCommand = new RelayCommand(()=>{ NavigateToAddUniversity(); });
为体会BindableApplicationBar.dll类库给我们带来的强大的功能,贴如下代码:
<bar:Bindable.ApplicationBar> <bar:BindableApplicationBar IsVisible="{Binding BarIsVisible}" IsMenuVisible="{Binding IsMenuVisible, Mode=TwoWay}" IsMenuEnabled="{Binding IsMenuEnabled}" ForegroundColor="{Binding ForegroundColor, Converter={StaticResource DoubleToColorConverter}}" BackgroundColor="{Binding BackgroundColor, Converter={StaticResource DoubleToColorConverter}}" BindableOpacity="{Binding Opacity}" Mode="{Binding Mode}" MenuItemsSource="{Binding MenuItems}" ButtonsSource="{Binding Buttons}"> <!--<bar:BindableApplicationBar.MenuItemTemplate> <DataTemplate> <bar:BindableApplicationBarMenuItem Text="{Binding Text}" Command="{Binding Command}" CommandParameter="{Binding CommandParameter}"/> </DataTemplate> </bar:BindableApplicationBar.MenuItemTemplate>--> <bar:BindableApplicationBarButton Text="{Binding IconButtonText}" IconUri="{Binding IconUri, FallbackValue=/Icons/Dark/appbar.add.rest.png}" IsEnabled="{Binding ButtonIsEnabled}" /> <bar:BindableApplicationBarButton Text="XAML Btn 2" IconUri="/Icons/Dark/appbar.next.rest.png" Command="{Binding TestCommand}" CommandParameter="{Binding TestCommandParameter}" /> <bar:BindableApplicationBar.MenuItems> <bar:BindableApplicationBarMenuItem Text="{Binding MenuItemText}" IsEnabled="{Binding MenuItemIsEnabled}" /> <bar:BindableApplicationBarMenuItem Text="XAML MnuIt 2" Command="{Binding TestCommand2}" CommandParameter="{Binding TestCommand2Parameter}" /> </bar:BindableApplicationBar.MenuItems> </bar:BindableApplicationBar> </bar:Bindable.ApplicationBar>
参考链接:
http://bindableapplicationb.codeplex.com/
MVVM模式应用 之为ApplicationBarIconButton 添加Command操作属性的更多相关文章
- 【转】ASP.NET MVC框架下使用MVVM模式-KnockOutJS+JQ模板例子
KnockOutJS学习系列----(一) 好几个月没去写博客了,最近也是因为项目紧张,不过这个不是借口,J. 很多时候可能是因为事情一多,然后没法静下来心来去写点东西,学点东西. 也很抱歉,突然看到 ...
- wp8使用mvvm模式简单例子
mvvm是silverlight/wpf下的mvc升华 通过一个简单的加法计算器例子来说明mvvm是什么 在设计界面完成设计之后,显示简单的布局,如下图: 然后来比较,传统的直接方式,mvc和mvvm ...
- WPF自学入门(十一)WPF MVVM模式Command命令 WPF自学入门(十)WPF MVVM简单介绍
WPF自学入门(十一)WPF MVVM模式Command命令 在WPF自学入门(十)WPF MVVM简单介绍中的示例似乎运行起来没有什么问题,也可以进行更新.但是这并不是我们使用MVVM的正确方式 ...
- 【转】【WPF】MVVM模式的3种command
1.DelegateCommand 2.RelayCommand 3.AttachbehaviorCommand 因为MVVM模式适合于WPF和SL,所以这3种模式中也有一些小差异,比如RelayCo ...
- MVVM模式的3种command总结[2]--RelayCommand
MVVM模式的3种command总结[2]--RelayCommand RelayCommand本来是WPF下面用的一种自定义的command,主要是它用到了事件管理函数,这个SL下面是没有的.不过这 ...
- MVVM模式的3种command总结[1]--DelegateCommand
MVVM模式的3种command总结[1]--DelegateCommand 查了不少资料,大概理清楚的就是有3种.当然类名可以自己取了,不过为了便于记忆和区分,还是和看到的文章里面用一样的类名. 1 ...
- WPF ContextMenu 在MVVM模式中绑定 Command及使用CommandParameter传参
原文:WPF ContextMenu 在MVVM模式中绑定 Command及使用CommandParameter传参 ContextMenu无论定义在.cs或.xaml文件中,都不继承父级的DataC ...
- 【WPF】MVVM模式的3种command
原文:[WPF]MVVM模式的3种command 1.DelegateCommand 2.RelayCommand 3.AttachbehaviorCommand 因为MVVM模式适合于WPF和SL, ...
- [转载]MVVM模式原理分析及实践
没有找到很好的MVVM模式介绍文章,简单找了一篇,分享一下.MVVM实现了UI\UE设计师(Expression Blend 4设计界面)和软件工程师的合理分工,在SilverLight.WPF.Wi ...
随机推荐
- HTML5 Canvas核心技术—图形、动画与游戏开发.pdf1
canvas元素可以说是HTML5元素中功能最强大的一个,它真正的能力是通过Canvas的context对象(绘图上下文)表现出来的 fillText()方法使用fillStyle属性来填充文本中的字 ...
- [ZETCODE]wxWidgets教程八:组件专题1
本教程原文链接:http://zetcode.com/gui/wxwidgets/widgets/ 翻译:瓶哥 日期:2013年12月12日星期四 邮箱:414236069@qq.com 主页:htt ...
- 《A First Course in Abstract Algebra with Applications》-chaper1-数论
由于笔者在别的专栏多次介绍过数论,这里在<抽象代数基础教程>的专栏下,对于chaper1数论这一章节介绍的方式不那么“入门”. 首先来介绍一个代数中常用也是非常重要的证明方法:数学归纳法. ...
- 斐波那契fib
输入N和N个数(N<=10,每个数<=10^17),对于每个数,要输出能用几个斐波那契数加加减减得到 样例输入: 35101070 样例输出: 124 直接拷题解: fib[i]表示斐波那 ...
- 如何设置textarea光标默认为第一行第一个字符
判断文本区是否有内容,如果没有那么光标肯定是在第一行第一个为止的,记住,空格回车也算是有内容在的,也会影响光标的位置
- 单点登录SSO的实现原理
单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任.单点登录在大型网站里使用得 ...
- Ajax交互demo1
一.概念 Ajax异步请求刷新. 浏览器在用户不知道的情况下,偷偷地跟服务器交互,然后返回数据给浏览器显示. 异步过程:当HTTP请求发送后,通过Ajax技术使用的XMLHttpRequest对象来发 ...
- 【硬件】DELLserver硬件监控及DELL系统管理工具OMSA介绍
1.1.1. DELLserver硬件监控及DELL系统管理工具OMSA介绍 本文介绍採用使用Nagios和OMSA监控DELLserver的硬件健康状态,Nagios监控的方式是NRPE模式,须要配 ...
- [PHP] find ascii code in string
if (strpos($data ,chr(0x95)) !== false) { echo 'true'; }else{ echo "false"; }
- MySQLdb安装和使用2
http://blog.chinaunix.net/uid-8487640-id-3183185.html MySQLdb是Python连接MySQL的模块,下面介绍一下源码方式安装MySQLdb: ...