背水一战 Windows 10 (24) - MVVM: 通过 Binding 或 x:Bind 结合 Command 实现,通过非 ButtonBase 触发命令
2021-05-13 01:27
                         标签:insert   ==   rabl   file   openxml   enter   删除   cal   取数    [源码下载] 作者:webabcd 示例 MVVM/Model/ProductDatabase.cs MVVM/ViewModel1/ProductViewModel.cs OK 背水一战 Windows 10 (24) - MVVM: 通过 Binding 或 x:Bind 结合 Command 实现,通过非 ButtonBase 触发命令 标签:insert   ==   rabl   file   openxml   enter   删除   cal   取数    原文地址:http://www.cnblogs.com/lonelyxmas/p/7567169.html
介绍
背水一战 Windows 10 之 MVVM(Model-View-ViewModel)
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));
            }
        }
    }
}
/*
 * Model 层的数据持久化操作(本地或远程)
 * 
 * 本例只是一个演示
 */
using System;
using System.Collections.Generic;
using System.Linq;
namespace Windows10.MVVM.Model
{
    public class ProductDatabase
    {
        private List
2、ViewModel
MVVM/ViewModel1/MyCommand.cs/*
 * 为了方便使用,把 ICommand 再封装一层
 */
using System;
using System.Windows.Input;
namespace Windows10.MVVM.ViewModel1
{
    public class MyCommand : ICommand
    {
        // 由 public void Execute(object parameter) 调用的委托
        public Actionobject> MyExecute { get; set; }
        // 由 public bool CanExecute(object parameter) 调用的委托
        public Funcobject, bool> MyCanExecute { get; set; }
        public MyCommand(Actionobject> execute, Funcobject, bool> canExecute)
        {
            this.MyExecute = execute;
            this.MyCanExecute = canExecute;
        }
        // 需要发布此事件的话,则调用 RaiseCanExecuteChanged 方法即可
        public event EventHandler CanExecuteChanged;
        public void RaiseCanExecuteChanged()
        {
            if (CanExecuteChanged != null)
            {
                CanExecuteChanged(this, EventArgs.Empty);
            }
        }
        // 用于决定当前绑定的 Command 能否被执行
        // parameter 是由 ButtonBase 的 CommandParameter 传递过来的
        // 如果返回 false 则对应的 ButtonBase 将变为不可用
        public bool CanExecute(object parameter)
        {
            return this.MyCanExecute == null ? true : this.MyCanExecute(parameter);
        }
        // 用于执行对应的命令,只有在 CanExecute() 返回 true 时才可以被执行
        // parameter 是由 ButtonBase 的 CommandParameter 传递过来的对象
        public void Execute(object parameter)
        {
            this.MyExecute(parameter);
        }
    }
}
/*
 * ViewModel 层
 *
 * 注:为了方便使用,此例对 ICommand 做了一层封装。如果需要了解比较原始的 MVVM 实现请参见 http://www.cnblogs.com/webabcd/archive/2013/08/29/3288304.html
 */
using System;
using System.Collections.ObjectModel;
using System.ComponentModel;
using Windows10.MVVM.Model;
namespace Windows10.MVVM.ViewModel1
{
    public class ProductViewModel : INotifyPropertyChanged
    {
        // 用于提供 Products 数据
        private ObservableCollection
3、View
MVVM/View/Demo1_2.xamlPage
    x:Class="Windows10.MVVM.View.Demo1_2"
    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:Interactivity="using:Microsoft.Xaml.Interactivity" 
    xmlns:Core="using:Microsoft.Xaml.Interactions.Core"
    
    xmlns:vm="using:Windows10.MVVM.ViewModel1">
    Grid Background="Transparent">
        StackPanel Margin="10 0 10 10">
            
            
            StackPanel.DataContext>
                vm:ProductViewModel />
            StackPanel.DataContext>
            ListView Name="listView" ItemsSource="{Binding Products}" Width="300" Height="300" HorizontalAlignment="Left" VerticalAlignment="Top">
                ListView.ItemTemplate>
                    DataTemplate>
                        StackPanel Orientation="Horizontal">
                            TextBlock Text="{Binding Name}" HorizontalAlignment="Left" />
                            TextBlock Text="{Binding Category}" HorizontalAlignment="Left" Margin="10 0 0 0" />
                        StackPanel>
                    DataTemplate>
                ListView.ItemTemplate>
            ListView>
            StackPanel Orientation="Horizontal" Margin="0 10 0 0" DataContext="{Binding Product}">
                TextBlock Text="Name:" VerticalAlignment="Center" />
                TextBox Name="txtName" Text="{Binding Name, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" Width="100" />
                TextBlock Text="Category:" VerticalAlignment="Center" Margin="20 0 0 0" />
                TextBox Name="txtCategory" Text="{Binding Category, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" Width="100" />
            StackPanel>
            
            StackPanel Orientation="Horizontal" Margin="0 10 0 0">
                TextBlock Text="查询">
                     Interactivity:Interaction.Behaviors>
                         Core:EventTriggerBehavior EventName="Tapped">
                             Core:InvokeCommandAction Command="{Binding GetProductsCommand}" />
                         Core:EventTriggerBehavior>
                     Interactivity:Interaction.Behaviors>
                TextBlock>
                TextBlock Text="添加" Margin="10 0 0 0">
                     Interactivity:Interaction.Behaviors>
                         Core:EventTriggerBehavior EventName="Tapped">
                             Core:InvokeCommandAction Command="{Binding AddProductCommand}" />
                         Core:EventTriggerBehavior>
                     Interactivity:Interaction.Behaviors>
                TextBlock>
                TextBlock Text="更新" Margin="10 0 0 0">
                     Interactivity:Interaction.Behaviors>
                         Core:EventTriggerBehavior EventName="Tapped">
                             Core:InvokeCommandAction Command="{Binding UpdateProductCommand}" CommandParameter="{Binding SelectedItem, ElementName=listView}"/>
                         Core:EventTriggerBehavior>
                     Interactivity:Interaction.Behaviors>
                TextBlock>
                TextBlock Text="删除" Margin="10 0 0 0">
                     Interactivity:Interaction.Behaviors>
                         Core:EventTriggerBehavior EventName="Tapped">
                             Core:InvokeCommandAction Command="{Binding DeleteProductCommand}" CommandParameter="{Binding SelectedItem, ElementName=listView}"/>
                         Core:EventTriggerBehavior>
                     Interactivity:Interaction.Behaviors>
                TextBlock>
            StackPanel>
        StackPanel>
    Grid>
Page>
[源码下载]
文章标题:背水一战 Windows 10 (24) - MVVM: 通过 Binding 或 x:Bind 结合 Command 实现,通过非 ButtonBase 触发命令
文章链接:http://soscw.com/index.php/essay/84937.html