分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow

详解WPF 4 DataGrid控件的基本功能

提到DataGrid 不管是网页还是应用程序开发都会频繁使用。通过它我们可以灵活的在行与列间显示各种数据。本篇将详细介绍WPF 4 中DataGrid 的相关功能。

自定义列

默认情况下,当我们为DataGrid 控件设置ItemSource 属性后,DataGrid 会根据数据类型自动生成相应的列,下表列出DataGrid 支持的四种列及其数据类型。

在创建DataGrid 时可以通过AutoGenerateColumns 属性设置列是否自动生成,从而加入自定义列。如果DataGrid 中同时包含“自动生成列”与“用户自定义列”,则首先创建“用户自定义列”。下面代码实例中分别创建这四种列:

<Window x:Class="WPF4ControlTest.MainWindow"        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"        xmlns:local="clr-namespace:WPF4ControlTest"        xmlns:assembly="clr-namespace:System;assembly=mscorlib"        Title="MainWindow" Height="200" Width="500">    <Window.Resources>        <ObjectDataProvider x:Key="sexEnum" MethodName="GetValues"                             ObjectType="{x:Type assembly:Enum}">            <ObjectDataProvider.MethodParameters>                <x:Type Type="local:SexOpt"/>            </ObjectDataProvider.MethodParameters>        </ObjectDataProvider>    </Window.Resources>    <Grid>        <DataGrid x:Name="dataGrid" ItemsSource="{Binding}" AutoGenerateColumns="False">            <DataGrid.Columns>                <DataGridTextColumn Header="Name" Width="80" Binding="{Binding Name}"/>                <DataGridTextColumn Header="Age" Width="50" Binding="{Binding Age}"/>                <DataGridComboBoxColumn Width="80" Header="Sex"                                         SelectedItemBinding="{Binding Sex}"                                         ItemsSource="{Binding Source={StaticResource sexEnum}}"/>                <DataGridCheckBoxColumn Header="Pass Exam?" Width="100"                                         Binding="{Binding Pass}"/>                <DataGridHyperlinkColumn Header="Email" Width="150"                                          Binding="{Binding Email}"/>            </DataGrid.Columns>        </DataGrid>    </Grid></Window>

其中每列都包含各自的数值类型,在C# 中创建Member 类及SexOpt 枚举,并将memberData 数据绑定到DataGrid:

using System;using System.Windows;using System.Collections.ObjectModel;namespace WPF4ControlTest{    /// <summary>    /// Interaction logic for MainWindow.xaml    /// </summary>    public partial class MainWindow : Window    {        public MainWindow()        {            InitializeComponent();            ObservableCollection<Member> memberData = new ObservableCollection<Member>();            memberData.Add(new Member()            {                Name = "Joe", Age = "23", Sex = SexOpt.Male,                Pass = true, Email = new Uri("mailto:Joe@school.com")            });            memberData.Add(new Member()            {                Name = "Mike", Age = "20",                Sex = SexOpt.Male, Pass = false,                Email = new Uri("mailto:Mike@school.com")            });            memberData.Add(new Member()            {                Name = "Lucy", Age = "25",                Sex = SexOpt.Female, Pass = true,                Email = new Uri("mailto:Lucy@school.com")            });            dataGrid.DataContext = memberData;        }    }    public enum SexOpt { Male, Female };    public class Member    {        public string Name { get; set; }        public string Age { get; set; }        public SexOpt Sex { get; set; }        public bool Pass { get; set; }        public Uri Email { get; set; }    }}

这样我们就可以通过自定义列的方式创建出DataGrid:

选择模式

默认情况下,DataGrid 的选择模式为“全行选择”,并且可以同时选择多行(如下图所示),我们可以通过SelectionModeSelectionUnit 属性来修改DataGrid 的选择模式。

SelectionUnit:包含CellFullRowCellOrRowHeader 三种单元选择模式。
                         · Cell:选择单元格;
                         · FullRow:选择全行;
                         · CellOrRowHeader:可选择单元格,也可以通过点击行首选择全行;

SelectionMode:分为ExtendedSingle 两种模式。
                           · Extended:选择多个单元(单元格或全行,由SelectionUnit 定义);
                           · Single:选择唯一单元(单元格或全行,由SelectionUnit 定义);

<DataGrid x:Name="dataGrid" ItemsSource="{Binding}" AutoGenerateColumns="False"          SelectionUnit="Cell" SelectionMode="Extended">… …

设置SelectionUnit 和SelectionMode 后的实例效果:

编辑

默认情况下,我们可以直接在DataGrid 中编辑数据(下表为相关的编辑命令),当然也可以通过IsReadOnly 属性将DataGrid 设置为只读方式。

<DataGrid x:Name="dataGrid" ItemsSource="{Binding}" AutoGenerateColumns="False"          SelectionUnit="Cell" SelectionMode="Extended" IsReadOnly="True">… …

其他设置

CanUserAddRows、CanUserDeleteRows、CanUserReorderColumns、CanUserResizeColumns、
CanUserResizeRows、CanUserSortColumns 、FrozenColumnCount、DisplayIndex

作者:李敬然(Gnie)
出处:{GnieTech} (http://www.cnblogs.com/gnielee/)
版权声明:本文的版权归作者与博客园共有。转载时须注明本文的详细链接,否则作者将保留追究其法律责任。

WPF中设置DataGrid的一些样式

    <Window.Resources>          <Style TargetType="DataGrid">              <!--拖动改变单元格大小-->              <Setter Property="CanUserResizeColumns" Value="false"/>              <!--网格线颜色-->              <Setter Property="HorizontalGridLinesBrush">                  <Setter.Value>                      <SolidColorBrush Color="LightBlue"/>                  </Setter.Value>              </Setter>              <Setter Property="VerticalGridLinesBrush">                  <Setter.Value>                      <SolidColorBrush Color="LightBlue"/>                  </Setter.Value>              </Setter>          </Style>                <!--标题栏样式-->          <Style  TargetType="DataGridColumnHeader" >              <Setter Property="Width" Value="50"/>              <Setter Property="FontSize" Value="14" />              <Setter Property="Background" Value="lightBlue" />              <!--加粗-->              <Setter  Property="FontWeight"  Value="Bold"/>          </Style>                <!--行样式触发-->          <!--背景色改变必须先设置cellStyle 因为cellStyle会覆盖rowStyle样式-->          <Style  TargetType="DataGridRow">              <Style.Triggers>                  <Trigger Property="IsSelected" Value="True">                      <Setter Property="BorderBrush" Value="Red" />                      <Setter Property="BorderThickness" Value="1" />                  </Trigger>                  <Trigger Property="IsMouseOver" Value="True">                      <Setter Property="Background" Value="LightGray"/>                  </Trigger>              </Style.Triggers>          </Style>                    <!--单元格样式触发-->          <Style TargetType="DataGridCell">              <Style.Triggers>                  <Trigger Property="IsSelected" Value="True">                      <Setter Property="Background" Value="White"/>                      <Setter Property="BorderThickness" Value="0"/>                      <Setter Property="Foreground" Value="Red"/>                  </Trigger>              </Style.Triggers>          </Style>      </Window.Resources>
var tempDataGrid = sender as DataGrid;
            if (tempDataGrid != null)
            {
                var frameworkElement = tempDataGrid.CurrentColumn.GetCellContent(tempDataGrid.SelectedItem);
                if (frameworkElement != null)
                {
                    string controllerName = frameworkElement.Name;
                    if (controllerName == "ControlName")
                    {
                         
                    }
                    else
                    {
                         
                    }
                }
            }

分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow

详解WPF 4 DataGrid控件的基本功能相关推荐

  1. WPF 4 DataGrid 控件(基本功能篇)

    提到DataGrid 不管是网页还是应用程序开发都会频繁使用.通过它我们可以灵活的在行与列间显示各种数据.本篇将详细介绍WPF 4 中DataGrid 的相关功能. 自定义列 默认情况下,当我们为Da ...

  2. WPF之DataGrid控件使用

    WPF之DataGrid控件使用 一.DataGrid简介 二.DataGrid数据源绑定 三.DataGrid单元格编辑触发事件 四.DataGrid增加删除行 五.DataGrid数据触发器 参考 ...

  3. WPF 自定义DataGrid控件样式

    WPF 自定义DataGrid控件样式 样式一: 样式代码: <!--DataGrid样式--><Style TargetType="DataGrid">& ...

  4. 有关WPF中DataGrid控件的基础应用总结

    基础说明 DataGrid是WPF提供的基础控件,它可以非常轻松的呈现出一张表格,本文章会按照从易到难的顺序依次将DataGrid的使用方法进行解说,除了MSDN上给出的最基本的例子之外,给出了三个比 ...

  5. WPF中DataGrid控件

    WPF中DataGrid控件的个别属性使用 //设置不可自动拉伸宽度dataGrid.CanUserResizeColumns = false;//第一列不可见dataGrid.HeadersVisi ...

  6. WPF(5)WPF之DataGrid控件

    系列文章目录 WPF(1)WPF工程创建 WPF(2)WPF之Image组件 WPF(3)WPF之Button组件 文章目录 系列文章目录 前言 一.DataGrid入门? 1.1 CanUserAd ...

  7. WPF 中DataGrid控件显示和设置数据

    一.基础知识 1.DataGrid控件:用来显示数据的控件,从对象集合中获取信息并在具有行和单元格的网格中显示信息.每行和单独的对象相对应,并且每列和对象的某个属性相对应. 2.在DataGrid 中 ...

  8. WPF的DataGrid控件样式自定义

    DataGrid控件很常用,不同的软件中,设计师呈现的UI样式不一样,参考了网上一些设置,先弄个简单的吧. 第一步,创建实体model, 第二步,写一个ViewModel,生成一些显示的数据 第三步, ...

  9. aspx repeater 用法_详解ASP.NET-----Repeater数据控件的用法总结

    一.Repeater控件的用法流程及实例: 1.首先建立一个网站,新建一个网页index.aspx. 2.添加或者建立APP_Data数据文件,然后将用到的数据库文件放到APP_Data文件夹中. 3 ...

最新文章

  1. 麻省理工开放官方课程项目!
  2. CountDownLatch——常用并发工具类
  3. 1011 World Cup Betting (20 分)_14行代码AC
  4. python根据坐标点画线_拖动鼠标绘制一条线,并在opencv中获得线端点的坐标Python...
  5. 掌握了这个方法,以后遇到bug不用再求人了!
  6. Linux shell命令最常用的快捷键
  7. labview利用簇模拟汽车控制_在LabVIEW应用程序中何时应采用面向对象技术 (翻译)...
  8. werkzeug SharedDataMiddleware
  9. paip.python 调用qt ui 总结
  10. 网络模型可视化工具netron
  11. FineReport学习-练习05-超级链接
  12. 数据安全态势感知解决方案汇总
  13. 论文理解记录:The Lottery Ticket Hypothesis
  14. H3C WX2510h无线控制器如何网关式部署无线网络
  15. Python图形界面开发框架常用的八款工具包
  16. java jtextfield 居中_java – 如何使JTextfield居中
  17. 数独(Sudoku)求解程序
  18. 2018年软件质量与测试大盘点
  19. 个人所得税计算C语言实现
  20. .isAssignableFrom的用法

热门文章

  1. LabVIEW控制Arduino驱动数码管(基础篇—11)
  2. python爬虫王者荣耀高清皮肤大图背景故事通用爬虫
  3. 2020牛客暑期多校训练营(第八场)I.Interesting Computer Game并查集
  4. ncae的c语言编程高阶怎么考,ncae考试科等目.doc
  5. opencv光线补偿_精准光线曝光补偿和包围曝光的运用
  6. 进程控制块pcb详解
  7. 基于云开发的二手书交易微信小程序
  8. Sporadic IOException: Failed to persist config
  9. AVA 代码覆盖率工具 JaCoCo-实践篇
  10. 【sqoop2】创建job报错There are issues with entered data, please revise your input