首页 > 其他分享 >wpf + MaterialDesign + Prism8 + DataGrid 实现表格内数据编辑,下拉

wpf + MaterialDesign + Prism8 + DataGrid 实现表格内数据编辑,下拉

时间:2023-12-26 14:15:03浏览次数:35  
标签:ObservableCollection obj private MaterialDesign DataGrid new using wpf public

十年河东,十年河西,莫欺少年穷

学无止境,精益求精

效果如下:

 xaml如下:

<UserControl x:Class="WpfApp.UserControls.MemoView"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
             xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
             xmlns:local="clr-namespace:WpfApp.UserControls" 
             xmlns:materialDesign="http://materialdesigninxaml.net/winfx/xaml/themes"
             xmlns:Model="clr-namespace:WpfApp.UserControlModels"
             mc:Ignorable="d" 
             d:DesignHeight="450" d:DesignWidth="800">
    <Grid>
        <Grid.RowDefinitions >
            <RowDefinition Height="auto"/>
            <RowDefinition/>
            <RowDefinition Height="45"/>
        </Grid.RowDefinitions>
        <!--<Border Background="Red" Height="40" Grid.Row="0"/>-->

        <DataGrid Grid.Row="1" AutoGenerateColumns="False" x:Name="MyDataGrid"
              CanUserAddRows="False"
              HeadersVisibility="All"
              ItemsSource="{Binding Books}">
            <DataGrid.Columns>
                <DataGridCheckBoxColumn Binding="{Binding isSelected}" Header="选择">

                    <DataGridCheckBoxColumn.HeaderStyle>
                        <Style TargetType="{x:Type DataGridColumnHeader}" BasedOn="{StaticResource MaterialDesignDataGridColumnHeader}">
                            <Setter Property="HorizontalContentAlignment" Value="Center" />
                        </Style>
                    </DataGridCheckBoxColumn.HeaderStyle>
                </DataGridCheckBoxColumn>
                <DataGridTextColumn Binding="{Binding bookNo}" Header="书号" Width="1*"/>
                <materialDesign:DataGridTextColumn Width="120"
                                           Binding="{Binding bookName}"
                                           EditingElementStyle="{StaticResource MaterialDesignDataGridTextColumnPopupEditingStyle}"
                                           Header="书名">
                    <DataGridTextColumn.HeaderStyle>
                        <Style TargetType="{x:Type DataGridColumnHeader}" BasedOn="{StaticResource MaterialDesignDataGridColumnHeader}">
                            <Setter Property="ContentTemplate">
                                <Setter.Value>
                                    <DataTemplate>
                                        <TextBlock Text="{Binding}"
                               TextAlignment="Right"
                               TextWrapping="Wrap" />
                                    </DataTemplate>
                                </Setter.Value>
                            </Setter>
                            <Setter Property="HorizontalContentAlignment" Value="Right" />
                        </Style>
                    </DataGridTextColumn.HeaderStyle>

                    <DataGridTextColumn.ElementStyle>
                        <Style TargetType="{x:Type TextBlock}" BasedOn="{StaticResource MaterialDesignDataGridTextColumnStyle}">
                            <Setter Property="HorizontalAlignment" Value="Right" />
                        </Style>
                    </DataGridTextColumn.ElementStyle>
                </materialDesign:DataGridTextColumn>
                <DataGridTextColumn Binding="{Binding bookAutor}" Header="作者" Width="1*" />
                <DataGridTextColumn Binding="{Binding bookCate}" Header="分类" Width="1*" />
                <DataGridTextColumn Binding="{Binding bookSite}" Header="出版社" Width="1*" />
                <materialDesign:DataGridComboBoxColumn
      Width="1*"
      Header="Food with long header"
      IsEditable="True"
                   ItemsSourceBinding="{Binding RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type DataGrid}}, Path=DataContext.BookSites}"
     
      SelectedValueBinding="{Binding bookSite}">

                </materialDesign:DataGridComboBoxColumn>
             
                <DataGridTextColumn Binding="{Binding Path=bookDate,StringFormat='yyyy年MM月dd日'}" Header="出版时间" Width="1*" />
                <DataGridTemplateColumn x:Name="UserAction" Header="操作" Width="180">
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <StackPanel Orientation="Horizontal">
                                <Button  Content="删除"   BorderBrush="AliceBlue"
                                    Command="{Binding DataContext.DeleteCmd, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=DataGrid}}"
                                            CommandParameter="{Binding }"
                                     HorizontalContentAlignment="Center" VerticalContentAlignment="Center">
                                </Button>

                                <Button Margin="12,0,0,0"  Content="编辑"  BorderBrush="AliceBlue"
                                    Command="{Binding DataContext.EditCmd, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=DataGrid}}"
                                            CommandParameter="{Binding }"
                                     HorizontalContentAlignment="Center" VerticalContentAlignment="Center">
                                </Button>
                            </StackPanel>
                            
                        </DataTemplate>
                        
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>  
            </DataGrid.Columns>
        </DataGrid> 
        <Button Grid.Row="2" Command="{Binding BtnCmd}" CommandParameter="{Binding ElementName=MyDataGrid,Path=SelectedItem}" Content="点我" Cursor="Hand"/>
    </Grid>
</UserControl>
View Code

CS 代码如下:

using Prism.Commands;
using Prism.Mvvm;
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Text;
using System.Windows;
using WpfApp.UserControlModels;

namespace WpfApp.ViewModels
{
    public class MemoViewModel: BindableBase
    {
        /// <summary>
        /// 分页后的数据
        /// </summary>
        private ObservableCollection<BookDto> books;
        public ObservableCollection<BookDto> Books
        {
            get { return books; }
            set { books = value; RaisePropertyChanged(); }
        }

        private ObservableCollection<string> bookSites;
        public ObservableCollection<string> BookSites
        {
            get { return bookSites; }
            set { bookSites = value; RaisePropertyChanged(); }
        }

        public DelegateCommand<BookDto> DeleteCmd { get; private set; }
        public DelegateCommand<BookDto> EditCmd { get; private set; }
        public DelegateCommand<BookDto> BtnCmd { get; private set; }
        
        public MemoViewModel()
        {
            CreateBook();
            BookSites = new ObservableCollection<string>() { "人民出版社", "江苏传媒出版社", "清华大学出版社" };
            DeleteCmd = new DelegateCommand<BookDto>(Delete);
            EditCmd = new DelegateCommand<BookDto>(Edit);
            BtnCmd = new DelegateCommand<BookDto>(BtnClick); 
        }

        private void BtnClick(BookDto obj)
        {
            MessageBox.Show(obj.bookName);
        }

        private void Edit(BookDto obj)
        {
            MessageBox.Show(obj.bookName);
        }

        private void Delete(BookDto obj)
        { 
            MessageBox.Show(obj.bookName);
        }

        public void CreateBook()
        {
            Books = new  ObservableCollection<BookDto> ();
            for (int i = 0; i < 25; i++)
            {
                BookDto dto = new BookDto()
                {
                    bookAutor = "作者" + i,
                    bookCate = "文学",
                    bookDate = DateTime.Now.AddMonths(-i),
                    bookName = "书名" + i,
                    bookNo = "0813092" + i,
                    bookPrice = 10,
                    bookSite = "人民出版社"
                };
                Books.Add(dto);
            }
           
        }
    }
}
View Code

说明如下:

1.绑定下拉框

  <materialDesign:DataGridComboBoxColumn
      Width="1*"
      Header="Food with long header"
      IsEditable="True"
      ItemsSourceBinding="{Binding RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type DataGrid}}, Path=DataContext.BookSites}"
      SelectedValueBinding="{Binding bookSite}">
  </materialDesign:DataGridComboBoxColumn>

ItemsSourceBinding 使用了相对资源查找器,AncestorType指: 获取或设置要查找的上级节点的类型。,path 为上下文的BookSites,选中的值为属性 bookSite

 2、编辑 和 删除 按钮

                <DataGridTemplateColumn x:Name="UserAction" Header="操作" Width="180">
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <StackPanel Orientation="Horizontal">
                                <Button  Content="删除"   BorderBrush="AliceBlue"
                                    Command="{Binding DataContext.DeleteCmd, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=DataGrid}}"
                                            CommandParameter="{Binding }"
                                     HorizontalContentAlignment="Center" VerticalContentAlignment="Center">
                                </Button>

                                <Button Margin="12,0,0,0"  Content="编辑"  BorderBrush="AliceBlue"
                                    Command="{Binding DataContext.EditCmd, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=DataGrid}}"
                                            CommandParameter="{Binding }"
                                     HorizontalContentAlignment="Center" VerticalContentAlignment="Center">
                                </Button>
                            </StackPanel>
                            
                        </DataTemplate>
                        
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>

3、设定日期格式

<DataGridTextColumn Binding="{Binding Path=bookDate,StringFormat='yyyy年MM月dd日'}" Header="出版时间" Width="1*" />

4、点我按钮,绑定dataGrid的选择项

 <Button Grid.Row="2" Command="{Binding BtnCmd}" CommandParameter="{Binding ElementName=MyDataGrid,Path=SelectedItem}" Content="点我" Cursor="Hand"/>

 

标签:ObservableCollection,obj,private,MaterialDesign,DataGrid,new,using,wpf,public
From: https://www.cnblogs.com/chenwolong/p/17927992.html

相关文章

  • WPF Halcon机器视觉和运动控制软件通用框架,插件式开发,开箱即用 仅供学习!
    点我下载,仅供个人学习使用参考easyvision开发,集成几十个软件算子此版本以添加ui设计器。具体功能如上所示,可以自定义变量,写c#脚本,自定义流程,包含了halcon脚本和封装的算子,可自定义ui,通过插件形式开发很方便拓展自己的功能。......
  • wpf + MaterialDesign + Prism8 + DataGrid 实现表格数据+分页
    十年河东,十年河西,莫欺少年穷学完止境,精益求精1、不分页,带有排序功能(每个字段都可以排序) xaml如下:<UserControlx:Class="WpfApp.UserControls.UserView"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http:......
  • 深入理解WPF中的Dispatcher:优化UI操作的关键
     概述:Dispatcher是WPF中用于协调UI线程和非UI线程操作的关键类,通过消息循环机制确保UI元素的安全更新。常见用途包括异步任务中的UI更新和定时器操作。在实践中,需注意避免UI线程阻塞、死锁,并使用CheckAccess方法确保在正确的线程上执行操作。这有助于提升应用程序的性能和用户......
  • 使用MVVM Toolkit简化WPF开发
    最近.NET8的WPF推出了 WPFFileDialog改进,这样无需再引用 Win32 命名空间就可以实现文件夹的选择与存储了,算是一个很方便的改进了。顺手写了一个小的WPF程序,在使用 Model-View-ViewModel(MVVM) 模式的时候,我不想使用 Prism 等重量级的框架,找了一个轻量级的MVVMCo......
  • 循序渐进介绍基于CommunityToolkit.Mvvm 和HandyControl的WPF应用端开发
    https://www.cnblogs.com/wuhuacong/tag/WPF/ 在我们的SqlSugar的开发框架中,整合了Winform端、Vue3+ElementPlus的前端、以及基于UniApp+Vue+ThorUI的移动前端几个前端处理,基本上覆盖了我们日常的应用模式了,本篇随笔进一步介绍前端应用的领域,研究集成WPF的应用端,循序渐进介绍基......
  • WPF MvvmToolkit入门
    最新.net6wpfMVVMToolkit8.0工程搭建。MVVMToolkit是一个轻量级MVVM框架,在框架下我们第一个要做的就是搞清在此框架下的一些常规操作:属性绑定和通知,命令绑定,消息传递。搞懂这些处理流程,然后就可以写自己业务的逻辑。1.安装mvvmtoolkit1.1Nuget下载CommunityToolkit.Mvvm......
  • [WPF] 使用 MVVM Toolkit 构建 MVVM 程序(CommunityToolkit.Mvvm)
    1.什么是MVVMToolkit模型-视图-视图模型(MVVM)是用于解耦UI代码和非UI代码的UI体系结构设计模式。借助MVVM,可以在XAML中以声明方式定义UI,并使用数据绑定标记将UI链接到包含数据和命令的其他层。微软虽然提出了MVVM,但又没有提供一个官方的MVVM库(多年前有过......
  • WPF+SqlSugar+MVVM实现增删改查
    1、新建一个WPF应用(NETFramework)2、安装SqlSugarNuGet包3、在SqlSugar4.x下载代码生成器https://www.donet5.com/Doc/8/11374、在WPF中新建三个文件夹Models主要放实体类、Views主要放窗体、ViewModels主要是View逻辑的实现5、把生成的实体类放到Models文件夹内,在V......
  • 浅谈WPF之DataGrid过滤,分组,排序
    使用过Excel的用户都知道,Excel可以方便的对数据进行分组,过滤,排序等操作,而在WPF中,默认提供的DataGrid只有很简单的功能,那么如何才能让我们开发的DataGrid,也像Excel一样具备丰富的客户端操作呢?今天就以一个简单的小例子,简述如何在WPF中实现DataGrid的过滤,筛选,排序等功能。仅供学习分......
  • wpf + LiveCharts.wpf 做个漂亮的图表
    十年河东,十年河西,莫欺少年穷学无止境,精益求精参考:WPFLiveChart图表详解接着上一篇博客: wpf+MaterialDesign+Prism8实现导航功能 1、项目引入图表包 2、定义用户控件IndexView的IndexViewModel,如下usingLiveCharts;usingPrism.Mvvm;usingSystem;using......