本文将接着上篇文章,介绍一下三点:(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

SimpleMVVMExample Demo下载

MVVM开发模式简单实例MVVM Demo【续】的更多相关文章

  1. MVVM开发模式简单实例MVVM Demo

    本文主要是翻译Rachel Lim的一篇有关MVVM模式介绍的博文 A Simple MVVM Example 并具体给出了一个简单的Demo(原文是以WPF开发的,对于我自己添加或修改的一部分会用红 ...

  2. js架构设计模式——理解javascript中的MVVM开发模式

    理解javascript中的MVVM开发模式 http://blog.csdn.net/slalx/article/details/7856769 MVVM的全称是Model View ViewMod ...

  3. 3.NetDh框架之缓存操作类和二次开发模式简单设计(附源码和示例代码)

    前言 NetDh框架适用于C/S.B/S的服务端框架,可用于项目开发和学习.目前包含以下四个模块 1.数据库操作层封装Dapper,支持多种数据库类型.多库实例,简单强大: 此部分具体说明可参考博客: ...

  4. 玩转Android之MVVM开发模式实战,炫酷的DataBinding!

    C# 很早就有了MVVM的开发模式,Android手机中的MVVM一直到去年Google的I\O大会上才推出,姗姗来迟.MVVM这中开发模式的优点自不必多说,可以实现视图和逻辑代码的解耦,而且,按照G ...

  5. (Hibernate进阶)Hibernate搭建开发环境+简单实例(二)

    hibernate是非常典型的持久层框架,持久化的思想是非常值得我们学习和研究的.这篇博文,我们主要以实例的形式学习Hibernate,不深究Hibernate的思想和原理,否则,一味追求,苦学思想和 ...

  6. 【SSH进阶之路】Hibernate搭建开发环境+简单实例(二)

    Hibernate是很典型的持久层框架,持久化的思想是很值得我们学习和研究的.这篇博文,我们主要以实例的形式学习Hibernate,不深究Hibernate的思想和原理,否则,一味追求,苦学思想和原理 ...

  7. Android之MVVM开发模式

    MVVM 模式简介 MVVM模式是指Model-View-ViewModel.相信看过笔者关于MVP的文章的读者也会发现,无论如何抽象化,在我们的View层中是无法避免的要处理一部分逻辑的.而MVVM ...

  8. 精通MVC网站、MVVM开发模式、Razor语法

    http://www.cnblogs.com/powertoolsteam/p/MVC_one.html ASP.NET MVC (一)——深入理解ASP.NET MVC 以下是ASP.NET MVC ...

  9. 从MVC -> MVVM ? 开发模式

    MVVM 到底是什么? view :由 MVC 中的 view 和 controller 组成,负责 UI 的展示,绑定 viewModel 中的属性,触发 viewModel 中的命令: viewM ...

随机推荐

  1. linux mail利用外部邮箱地址发邮件

    mail命令发送邮件需要sendmail或postfix服务 三种常用格式发信 mail -s "标题" xxx@xxx.xxx #第一种方法,你可以把当前shell当成编辑器来用 ...

  2. MMORPG大型游戏设计与开发(服务器 游戏场景 多线程)

    多线程在随着cpu发展应用的是越来越多,游戏场景因为其在服务器所占的数据量与逻辑复杂度的原因必须依赖于它.为什么场景要采用多线程?场景的线程是怎样的?场景的线程又是如何创建的?场景的线程又是怎样管理的 ...

  3. CF733D Kostya the Sculptor[贪心 排序]

    D. Kostya the Sculptor time limit per test 3 seconds memory limit per test 256 megabytes input stand ...

  4. weka

    第一次接触weka这个东西,貌似是数据挖掘用的比较多.接下来一个月里,希望能够对weka有更深一步的了解,并用博客记录下学习weka用法.原理.数据预处理的过程,与君分享,期待!

  5. BZOJ1856[SCOI2010]字符串

    Description lxhgww最近接到了一个生成字符串的任务,任务需要他把n个1和m个0组成字符串,但是任务还要求在组成的字符串中,在任意的前k个字符中,1的个数不能少于0的个数.现在lxhgw ...

  6. .jshintrc配置

    在root目录创建一个.jshintrc文件插入下面的代码即可.也可以自行配置. { // // 强制选项 // // When set to true, these options will mak ...

  7. NPOI导出Excel合并表头写入公式

    protected void Btn1_Click(object sender, EventArgs e) { //建立空白工作簿 IWorkbook workbook = new HSSFWorkb ...

  8. [转有改动]vi

    转自http://www.51testing.com/html/86/427686-247344.html 多按几次[ESC],系统会发出滴滴声以确定进入命令模式.就进入了命令模式,所有在键盘上打的字 ...

  9. JS组件系列——Bootstrap 树控件使用经验分享

    前言:很多时候我们在项目中需要用到树,有些树仅仅是展示层级关系,有些树是为了展示和编辑层级关系,还有些树是为了选中项然后其他地方调用选中项.不管怎么样,树控件都是很多项目里面不可或缺的组件之一.今天, ...

  10. __ block

    1.__block对象在block中是可以被修改.重新赋值的. 2.__block对象在block中不会被block强引用一次,从而不会出现循环引用问题. API Reference对__weak变量 ...