WPF中基于CommunityToolkit.Mvvm 框架的Datagrid动态变化实现

前言

        MVVM是在WPF开发中常用的一种模式,本文介绍基于微软官方的一款MVVM框架CommunityToolkit.Mvvm实现datagrid控件的动态变换

安装

在NuGet管理器中搜索CommunityToolkit.Mvvm 并安装

 页面

 HTML

 <Grid>
            <Grid.RowDefinitions>
                <RowDefinition/>
                <RowDefinition/>
            </Grid.RowDefinitions>

            <DataGrid x:Name="grid" ItemsSource="{Binding Datalist, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" IsReadOnly="True" AutoGenerateColumns="False" CanUserAddRows="False">
                <DataGrid.Columns>
                    <DataGridTextColumn Header="Code" Binding="{Binding Code}"></DataGridTextColumn>
                    <DataGridTextColumn Header="Name" Binding="{Binding Name}"></DataGridTextColumn>
                    <DataGridTemplateColumn Header="操作">
                        <DataGridTemplateColumn.CellTemplate>
                            <DataTemplate>
                                <StackPanel Orientation="Horizontal">
                                    <Border Width="10" Height="10" Background="{Binding Code}"></Border>
                                    <TextBlock Margin="10,0" Text="{Binding Name}"></TextBlock>
                                </StackPanel>
                            </DataTemplate>
                        </DataGridTemplateColumn.CellTemplate>
                    </DataGridTemplateColumn>
                </DataGrid.Columns>
            </DataGrid>
            <StackPanel Grid.Row="1" Orientation="Horizontal" HorizontalAlignment="Right">
                <TextBox  Height="100" Width="200" Background="Yellow" Text="{Binding Path=Name,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}"/>
                <Button Width="200" Content="开始" Height="100" Command="{Binding ShowMyCommand}"></Button>
            </StackPanel>
        </Grid>

MainWIndow后台代码

 public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
            this.DataContext=new MyViewModel();
            //注册
            WeakReferenceMessenger.Default.Register<MessageModel>(this, OnReceive);
        }
        
        private void OnReceive(object recipient, MessageModel message)
        {
            
            MessageBox.Show(message.Message+message.Date);
        }
    }

 

新建类

新建ColorModel,MessageModel,MyViewModel三个类

 ColorModel

public class ColorModel
    {
        public string Code { get; set; }
        public string Name { get; set; }
    }

messageModel 

internal class MessageModel
    {
            public string Title { get; set; }
            public string Message { get; set; }
            public int Id { get; set; }
            public DateTime Date { get; set; }
      
    }

MyViewModel 

public class MyViewModel: ObservableObject
    {
        public MyViewModel()
        {
            Name = "holle";
            ShowMyCommand = new RelayCommand(Show);
            timer.Elapsed += timer_Tick;
            timer.Interval = 1000;

            Datalist.Add(new ColorModel() { Code = "#9F5F9F", Name = "#蓝紫色" });
            Datalist.Add(new ColorModel() { Code = "#B5A642", Name = "#黄铜色" });
            Datalist.Add(new ColorModel() { Code = "#D9D919", Name = "#亮金色" });
            Datalist.Add(new ColorModel() { Code = "#5F9F9F", Name = "#士官服蓝色" });
            Datalist.Add(new ColorModel() { Code = "#D98719", Name = "#冷铜色" });

           
        }
        public RelayCommand ShowMyCommand { get; set; }//命令

        private System.Timers.Timer timer { get; set; } = new System.Timers.Timer();
        private string name;
        public string Name
        {
            get { return name; }
            set
            {
                name = value;
                OnPropertyChanged();//属性通知
            }
        }
        private ObservableCollection<ColorModel> datalist=new ObservableCollection<ColorModel>();
        public ObservableCollection<ColorModel> Datalist
        {
            get { return datalist; }
            set
            {
                datalist = value;
                OnPropertyChanged();//属性通知
            }
        }
        public void Show()
        {
           
            if(!timer.Enabled)
            {
                timer.Stop();
                Name = "定期时器关闭";
            }
            {
                timer.Start();
                Name = "定期时器启动";
            }
            //发送Messge
            WeakReferenceMessenger.Default.Send(new MessageModel() { Date=DateTime.Now,Message= Name });
        }
        private void timer_Tick(object sender,EventArgs e)
        {
            System.Windows.Application.Current.Dispatcher.Invoke((Action)(() =>
            {
                Datalist.Insert(0,Datalist[Datalist.Count - 1]);
                Datalist.RemoveAt(Datalist.Count-1);
            }));

           
          
        }
       
    }

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值