MVVM开发模式简单实例MVVM Demo【续】
本文将接着上篇文章,介绍一下三点:(Universal App)
1.将添加Product集合,绑定到列表
2.给点击ListBox的添加选项改变时的事件(要附加依赖属性,和Button点击事件不同)
3.通过自定义类以JSON获取保存数据到存储空间
-------------------------------------------------
1.添加集合,绑定列表,支持可操作
在ProductViewModel中添加字段、属性:
private ObservableCollection<ProductModel> _products;
public ObservableCollection<ProductModel> Product //产品集合
{
get { return _products; }
set
{
SetProperty(ref this._products, value);
}
}
并在构造函数中添加实例化语句
public ProductViewModel()
{
Products = new ObservableCollection<ProductModel>();
}
前台ListBox代码
<在View后台,this.DataContext = product; 也就是说ListBox.dataContext也是一样的>
<ListBox ItemsSource="{Binding Products}">
<ListBox.ItemTemplate>
<DataTemplate>
<StackPanel>
<TextBlock Text="{Binding ProductId}"/>
<TextBlock Text="{Binding ProductName}"/>
<TextBlock Text="{Binding UnitPrice}"/>
</StackPanel>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
将保存数据的事件改写为
public void SaveProduct()
{
//await new MessageDialog("保存").ShowAsync();
Products.Add(CurrentProduct); //添加数据到集合中
}
每一次输入数字后,保存,ListBox数据将会增加。(你们可以自己试着实现删除。)
2.给ListBox添加事件(相当于SelectedChanged) 我们要使用依赖属性
新增一个SelectionChangedBehavior类
public static class SelectionChangedBehavior
{
public static readonly DependencyProperty SelectionChangedCommandProperty =
DependencyProperty.RegisterAttached(
"SelectionChangedCommand",
typeof(ICommand),
typeof(SelectionChangedBehavior),
new PropertyMetadata(null, new PropertyChangedCallback(SeletionChangedPropertyChangedCallback))); public static ICommand GetSelectionChangedCommand(DependencyObject d)
{
return (ICommand)d.GetValue(SelectionChangedCommandProperty);
} public static void SetSelectionChangedCommand(DependencyObject d, ICommand value)
{
d.SetValue(SelectionChangedCommandProperty, value);
} public static void SeletionChangedPropertyChangedCallback(DependencyObject d, DependencyPropertyChangedEventArgs e)
{
((ListBox)d).SelectionChanged += (ss, ee) =>
{
ListBox lv = ss as ListBox;
GetSelectionChangedCommand(lv).Execute(lv.SelectedItem);
};
}
}
在View.xaml中
添加引用 xmlns:behavior="using:SimpleMVVMExample.Common" 位置为上述类所在位置
给ListBox添加属性
<ListBox ItemsSource="{Binding Products}"
behavior:SelectionChangedBehavior.SelectionChangedCommand="{Binding SelectionChangedCommand}" >
现在去ProductViewModel实现SelectionChangedCommand;
private ICommand _selectionChangedCommand;
public ICommand SelectionChangedCommand
{
get
{
if (_selectionChangedCommand == null)
_selectionChangedCommand = new RelayCommand(SelectionChanged);
return _selectionChangedCommand;
}
} public void SelectionChanged(object parameter)
{
ProductModel productModel = parameter as ProductModel;
//这已经获取到了
//具体要做些什么事情 自己处理
}
3.利用生命周期来向设置中保存、提取数据
A.自定义类转换为JSON
ProductViewModel.cs
public void SaveData()
{
var settings = ApplicationData.Current.LocalSettings;
string json = this.Stringify();
settings.Values["ViewModel"] = json;
}
private string Stringify()
{
JsonObject jsonObject = new JsonObject();
JsonArray jsonArray = new JsonArray(); foreach (ProductModel item in Products)
{
jsonArray.Add(item.ToJsonObject());
} JsonObject products = new JsonObject();
products.SetNamedValue("ProductsKey", jsonArray);
products.SetNamedValue("NewId", JsonValue.CreateNumberValue(_productId));
jsonObject.SetNamedValue("SaveKey", products);
return jsonObject.Stringify();
}
ProductModel.cs
public JsonObject ToJsonObject()
{
JsonObject jsonObject = new JsonObject();
jsonObject.SetNamedValue("NameKey", JsonValue.CreateStringValue(ProductName));
jsonObject.SetNamedValue("IdKey", JsonValue.CreateNumberValue(ProductId));
jsonObject.SetNamedValue("PriceKey", JsonValue.CreateNumberValue((double)UnitPrice)); JsonObject product = new JsonObject();
product.SetNamedValue("ProductKey", jsonObject);
return product;
}
自己画的结构示意图。。。

B.JSON转换为自定义类
ProductViewModel.cs:
public void GetData()
{
string setting = ApplicationData.Current.LocalSettings.Values["ViewModel"].ToString();
ProductViewModel productViewModel = new ProductViewModel(setting);
this._productId = productViewModel._productId;
this._products = productViewModel.Products;
} public ProductViewModel(string jsonString)
{
this.Products = new ObservableCollection<ProductModel>();
JsonObject jsonOject = JsonObject.Parse(jsonString);
this.ProductId = (int)jsonOject.GetNamedObject("SaveKey").GetNamedNumber("NewId");
foreach (var item in jsonOject.GetNamedObject("SaveKey").GetNamedArray("ProductsKey", new JsonArray()))
{
if (item.ValueType == JsonValueType.Object)
{
this.Products.Add(new ProductModel(item.GetObject()));
}
}
}
ProductModel.cs
public ProductModel(JsonObject jsonObject)
{
JsonObject productObject = jsonObject.GetNamedObject("ProductKey");
if (productObject != null)
{
this.ProductId = (int)productObject.GetNamedNumber("IdKey");
this.ProductName = (string)productObject.GetNamedString("NameKey");
this.UnitPrice = (decimal)productObject.GetNamedNumber("PriceKey");
}
}
C.View生命周期
private void NavigationHelper_LoadState(object sender, LoadStateEventArgs e)
{
if (ApplicationData.Current.LocalSettings.Values.ContainsKey("ViewModel"))
{
product.GetData();
}
}
private void NavigationHelper_SaveState(object sender, SaveStateEventArgs e)
{
product.SaveData();
}
注: 上一篇文章里说了,MVVM下,在Model里不能包括任何方法,而此处转换JSON时,在Model里面的方法应该不规范。
可以在ProductViewModel里面实现。 这里只是给出进行转换的方法。写在ViewModel的保存、取出设置内容也是一样。
下面给出Demo: 为Universal App
MVVM开发模式简单实例MVVM Demo【续】的更多相关文章
- MVVM开发模式简单实例MVVM Demo
本文主要是翻译Rachel Lim的一篇有关MVVM模式介绍的博文 A Simple MVVM Example 并具体给出了一个简单的Demo(原文是以WPF开发的,对于我自己添加或修改的一部分会用红 ...
- js架构设计模式——理解javascript中的MVVM开发模式
理解javascript中的MVVM开发模式 http://blog.csdn.net/slalx/article/details/7856769 MVVM的全称是Model View ViewMod ...
- 3.NetDh框架之缓存操作类和二次开发模式简单设计(附源码和示例代码)
前言 NetDh框架适用于C/S.B/S的服务端框架,可用于项目开发和学习.目前包含以下四个模块 1.数据库操作层封装Dapper,支持多种数据库类型.多库实例,简单强大: 此部分具体说明可参考博客: ...
- 玩转Android之MVVM开发模式实战,炫酷的DataBinding!
C# 很早就有了MVVM的开发模式,Android手机中的MVVM一直到去年Google的I\O大会上才推出,姗姗来迟.MVVM这中开发模式的优点自不必多说,可以实现视图和逻辑代码的解耦,而且,按照G ...
- (Hibernate进阶)Hibernate搭建开发环境+简单实例(二)
hibernate是非常典型的持久层框架,持久化的思想是非常值得我们学习和研究的.这篇博文,我们主要以实例的形式学习Hibernate,不深究Hibernate的思想和原理,否则,一味追求,苦学思想和 ...
- 【SSH进阶之路】Hibernate搭建开发环境+简单实例(二)
Hibernate是很典型的持久层框架,持久化的思想是很值得我们学习和研究的.这篇博文,我们主要以实例的形式学习Hibernate,不深究Hibernate的思想和原理,否则,一味追求,苦学思想和原理 ...
- Android之MVVM开发模式
MVVM 模式简介 MVVM模式是指Model-View-ViewModel.相信看过笔者关于MVP的文章的读者也会发现,无论如何抽象化,在我们的View层中是无法避免的要处理一部分逻辑的.而MVVM ...
- 精通MVC网站、MVVM开发模式、Razor语法
http://www.cnblogs.com/powertoolsteam/p/MVC_one.html ASP.NET MVC (一)——深入理解ASP.NET MVC 以下是ASP.NET MVC ...
- 从MVC -> MVVM ? 开发模式
MVVM 到底是什么? view :由 MVC 中的 view 和 controller 组成,负责 UI 的展示,绑定 viewModel 中的属性,触发 viewModel 中的命令: viewM ...
随机推荐
- EF6 Create Different DataContext on runtime(运行时改变连接字符串)
引言 在使用EF时,有时我们需要在程序运行过程中动态更改EF的连接字符串,但不幸的时EF是否对 ConfigurationManager.RefreshSection("xxx" ...
- BZOJ1057[ZJOI2007]棋盘制作 [单调栈]
题目描述 国际象棋是世界上最古老的博弈游戏之一,和中国的围棋.象棋以及日本的将棋同享盛名.据说国际象棋起源于易经的思想,棋盘是一个8*8大小的黑白相间的方阵,对应八八六十四卦,黑白对应阴阳. 而我们的 ...
- NOIP2008双栈排序[二分图染色|栈|DP]
题目描述 Tom最近在研究一个有趣的排序问题.如图所示,通过2个栈S1和S2,Tom希望借助以下4种操作实现将输入序列升序排序. 操作a 如果输入序列不为空,将第一个元素压入栈S1 操作b 如果栈S1 ...
- sqlServer数据库实现不同库之间表迁移
(1) (2) 点击开始便进行数据库到库的迁移.
- BZOJ 2115 【Wc2011】 Xor
Description Input 第一行包含两个整数N和 M, 表示该无向图中点的数目与边的数目. 接下来M 行描述 M 条边,每行三个整数Si,Ti ,Di,表示 Si 与Ti之间存在 一条权值为 ...
- C#.NET 大型通用信息化系统集成快速开发平台 4.1 版本 - 密码强化、网络安全强化
公司的系统庞大后,用户数量也庞大,容易引起各种网络安全相关问题,需要把每个用户的网络安全意识都提高,由于历史原因有些用户的密码过于简单,很容易被猜到,引起很多没必要的麻烦. 系统登录成功后,检查密码复 ...
- 简单的Viewing Frustum Culling
Viewing Frustum Culling是图形绘制流水线中,将不可见物体(即不在视锥体内的物体)提前剔除的操作. 在实践中,精确判断物体的可见性开销较大,因而通常用物体包围球或包围盒与视锥体(平 ...
- EF批量添加数据性能慢的问题的解决方案
//EF批量添加数据性能慢的问题的解决方案 public ActionResult BatchAdd() { using (var db = new ToneRoad.CEA.DbContext.Db ...
- C语言初级进阶1
1.数据类型1.1.基本数据类型数据类型分2类:基本数据类型+复合类型基本类型:char short int long float double复合类型:数组 结构体 共用体 类(C语言没有类,C++ ...
- RPC
那是N年前的一天,老王在看一本讲java的技术书(可惜忘了叫啥名字了),突然看到有一章讲RMI的,立马就觉得很好奇.于是乎,就按书上所讲,写了demo程序.当时也就只知道怎么用,却不知道什么原理.直到 ...