设为首页 收藏本站
查看: 801|回复: 0

[经验分享] 背水一战 Windows 10 (25)

[复制链接]

尚未签到

发表于 2017-6-28 12:22:36 | 显示全部楼层 |阅读模式
  [源码下载]




背水一战 Windows 10 (25) - MVVM: 通过 x:Bind 实现 MVVM(不用 Command)  
作者:webabcd

介绍
背水一战 Windows 10 之 MVVM(Model-View-ViewModel)


  • 通过 x:Bind 实现 MVVM(不用 Command)
  
示例
1、Model
MVVM/Model/Product.cs



/*
* Model 层的实体类,如果需要通知则需要实现 INotifyPropertyChanged 接口
*/
using System.ComponentModel;
namespace Windows10.MVVM.Model
{
public class Product : INotifyPropertyChanged
{
public Product()
{
ProductId = 0;
Name = "";
Category = "";
}
private int _productId;
public int ProductId
{
get { return _productId; }
set
{
_productId = value;
RaisePropertyChanged(nameof(ProductId));
}
}
private string _name;
public string Name
{
get { return _name; }
set
{
_name = value;
RaisePropertyChanged(nameof(Name));
}
}
private string _category;
public string Category
{
get { return _category; }
set
{
_category = value;
RaisePropertyChanged(nameof(Category));
}
}

public event PropertyChangedEventHandler PropertyChanged;
protected void RaisePropertyChanged(string name)
{
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs(name));
}
}
}
}
  MVVM/Model/ProductDatabase.cs



/*
* Model 层的数据持久化操作(本地或远程)
*
* 本例只是一个演示
*/
using System;
using System.Collections.Generic;
using System.Linq;
namespace Windows10.MVVM.Model
{
public class ProductDatabase
{
private List<Product> _products = null;
public List<Product> GetProducts()
{
if (_products == null)
{
Random random = new Random();
_products = new List<Product>();
for (int i = 0; i < 100; i++)
{
_products.Add
(
new Product
{
ProductId = i,
Name = "Name" + i.ToString().PadLeft(4, '0'),
Category = "Category" + (char)random.Next(65, 91)
}
);
}
}
return _products;
}
public List<Product> GetProducts(string name, string category)
{
return GetProducts().Where(p => p.Name.Contains(name) && p.Category.Contains(category)).ToList();
}
public void Update(Product product)
{
var oldProduct = _products.Single(p => p.ProductId == product.ProductId);
oldProduct = product;
}
public Product Add(string name, string category)
{
Product product = new Product();
product.ProductId = _products.Max(p => p.ProductId) + 1;
product.Name = name;
product.Category = category;
_products.Insert(0, product);
return product;
}
public void Delete(Product product)
{
_products.Remove(product);
}
}
}
  
2、ViewModel
MVVM/ViewModel2/ProductViewModel.cs



/*
* ViewModel 层
*/
using System.Collections.ObjectModel;
using System.ComponentModel;
using Windows.UI.Xaml;
using Windows10.MVVM.Model;
namespace Windows10.MVVM.ViewModel2
{
public class ProductViewModel : INotifyPropertyChanged
{
// 用于提供 Products 数据
private ObservableCollection<Product> _products;
public ObservableCollection<Product> Products
{
get { return _products; }
set
{
_products = value;
RaisePropertyChanged(nameof(Products));
}
}
// 用于“添加”和“查询”的 Product 对象
private Product _product;
public Product Product
{
get { return _product; }
set
{
_product = value;
RaisePropertyChanged(nameof(Product));
}
}
// 数据库对象
private ProductDatabase _context = null;
public ProductViewModel()
{
_context = new ProductDatabase();
Product = new Product();
Products = new ObservableCollection<Product>(_context.GetProducts());
}

public void GetProducts(object sender, RoutedEventArgs e)
{
// 从 Model 层获取数据
Products = new ObservableCollection<Product>(_context.GetProducts(Product.Name, Product.Category));
}
public void AddProduct(object sender, RoutedEventArgs e)
{
// 在 Model 层添加一条数据
Product newProduct = _context.Add(Product.Name, Product.Category);
// 更新 ViewModel 层数据
Products.Insert(0, newProduct);
}
public void UpdateProduct(object sender, RoutedEventArgs e)
{
Product product = ((FrameworkElement)sender).Tag as Product;
// 更新 ViewModel 层数据
product.Name = product.Name + "U";
product.Category = product.Category + "U";
// 更新 Model 层数据
            _context.Update(product);
}
public void DeleteProduct(object sender, RoutedEventArgs e)
{
Product product = ((FrameworkElement)sender).Tag as Product;
// 更新 Model 层数据
            _context.Delete(product);
// 更新 ViewModel 层数据
            Products.Remove(product);
}

public event PropertyChangedEventHandler PropertyChanged;
protected void RaisePropertyChanged(string name)
{
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs(name));
}
}
}
}
  
3、View
MVVM/View/Demo2.xaml



<Page
x:Class="Windows10.MVVM.View.Demo2"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.MVVM.View"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
xmlns:model="using:Windows10.MVVM.Model">
<Grid Background="Transparent">
<StackPanel Margin="10 0 10 10">
<!--
View 层
-->
<!--
本例通过 x:Bind 实现 MVVM(不用 Command)
-->
<ListView Name="listView" ItemsSource="{x:Bind ProductViewModel.Products, Mode=OneWay}" Width="300" Height="300" HorizontalAlignment="Left" VerticalAlignment="Top">
<ListView.ItemTemplate>
<DataTemplate x:DataType="model:Product">
<StackPanel Orientation="Horizontal">
<TextBlock Text="{x:Bind Name, Mode=OneWay}" HorizontalAlignment="Left" />
<TextBlock Text="{x:Bind Category, Mode=OneWay}" HorizontalAlignment="Left" Margin="10 0 0 0" />
</StackPanel>
</DataTemplate>
</ListView.ItemTemplate>
</ListView>
<StackPanel Orientation="Horizontal" Margin="0 10 0 0">
<TextBlock Text="Name:" VerticalAlignment="Center" />
<TextBox Name="txtName" Text="{x:Bind ProductViewModel.Product.Name, Mode=TwoWay}" Width="100" />
<TextBlock Text="Category:" VerticalAlignment="Center" Margin="20 0 0 0" />
<TextBox Name="txtCategory" Text="{x:Bind ProductViewModel.Product.Category, Mode=TwoWay}" Width="100" />
</StackPanel>
<StackPanel Orientation="Horizontal" Margin="0 10 0 0">
<Button Name="btnSearch" Content="查询" Click="{x:Bind ProductViewModel.GetProducts}" Margin="10 0 0 0" />
<Button Name="btnAdd" Content="添加" Click="{x:Bind ProductViewModel.AddProduct}" Margin="10 0 0 0" />
<Button Name="btnUpdate" Content="更新" Click="{x:Bind ProductViewModel.UpdateProduct}" Tag="{x:Bind listView.SelectedItem, Mode=OneWay}" Margin="10 0 0 0" />
<Button Name="btnDelete" Content="删除" Click="{x:Bind ProductViewModel.DeleteProduct}" Tag="{x:Bind listView.SelectedItem, Mode=OneWay}" Margin="10 0 0 0" />
</StackPanel>
</StackPanel>
</Grid>
</Page>
  
OK
[源码下载]

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-388975-1-1.html 上篇帖子: Windows,caffe 仅cpu 下篇帖子: windows下Nginx配置与测试
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表