- 浏览: 52153 次
- 性别:
- 来自: 厦门
文章分类
最新评论
DataGrid是WPF中的数据显示控件,相当于Winform中的DataGridView。但是两者之间的用法确存在一些差异。在文档中,如果利用两者的不同之处可以更加清楚的描述好DataGrid的使用,我将采用该种方法。好了我们首先看一下如何为DataGrid指定数据源吧!
我们知道在Winform中DataGridView的数据源可以是DataTable,DataView,List<T>等,但是在WPF中DataGrid的数据源不能直接为DataTable。作为DataGrid的数据源的对象必须实现了IEnumerable接口的,至于你们是否怀疑DataGrid的数据源真的不能直接指定为DataTable?那最好是自己去尝试一下。因为求知就得如此。我是试过了哈!如果你真的要将DataTable指定给DataGrid。那么你可以采用以下方法:this.dataGrid.ItemSource = dt.DefaultView;这里的dt是你创建的DataTable对象。你注意到了吗?先前我们使用的诸如DataGridView,ComboBox,Web中的GridView等数据显示控件在指定数据源时都是为其属性DataSource指定数据源对象。但是WPF中的DataGrid却不是这样,我开始接触的时候按照自己的思维方式去找寻DataSource属性,可未成功!查阅资料才知道是ItemSource属性。所以请注意了!
我们在使用DataGrid控件时,可以直接将数据源对象指定给DataGrid的ItemSource属性。此时数据显示将按照数据源的数据结构进行数据显示。如果你需要根据你自己定义的方式显示数据,此时需要借助于代码定义样式了!DataGrid的整体外观我们可以通过设置DataGrid的属性来体现,也可以通过Style来体现。如利用DataGrid的HeadersVisibility设置头或列是否显示,该属性有三个值,分别的含义是:None 表示列头和行头都不显示; All 表示列头和行头都显示; Row表示行头显示; Column 表示列头显示;利用DataGrid的RowBackgroud属性设置行的背景色等等。我们也可以利用设置DataGrid的Style来控制DataGrid的外观样式。如利用DataGrid.ColumnHeaderStyle来设置DataGrid的列头显示样式,示例代码如下:
<DataGrid.ColumnHeaderStyle> <Style TargetType="DataGridColumnHeader"> <Setter Property="Background"> <Setter.Value> <LinearGradientBrush StartPoint="0,0" EndPoint="0,1"> <GradientStop Color="White" Offset="0"/> <GradientStop Color="Yellow" Offset="0.5"/> <GradientStop Color="White" Offset="1"/> </LinearGradientBrush> </Setter.Value> </Setter> <Setter Property="Foreground" Value="Black"/> <Setter Property="FontSize" Value="13" /> </Style> </DataGrid.ColumnHeaderStyle>
以上代码分别对DataGrid的列头的背景色、前景色和字体做了设置。其中在设置背景色时,利用了(LinearGradientBrush)使其背景色呈渐变效果。
利用DataGrid.RowHeaderStyle来设置DataGrid的行头显示样式,示例代码如下:
<DataGrid.RowHeaderStyle> <Style TargetType="DataGridRowHeader"> <Setter Property="Content" Value=" •¤"/> <Setter Property="Width" Value="10"/> <Setter Property="Background"> <Setter.Value> <LinearGradientBrush StartPoint="0,0" EndPoint="1,1"> <GradientStop Color="White" Offset="0"/> <GradientStop Color="SkyBlue" Offset="1"/> </LinearGradientBrush> </Setter.Value> </Setter> <Style.Triggers> <Trigger Property="IsMouseOver" Value="True"> <Setter Property="ToolTip" Value="选中该行"/> </Trigger> </Style.Triggers> </Style> </DataGrid.RowHeaderStyle>
看着这些代码,与刚刚的ColumnHeaderStyle的代码大同小异,在此我想说的是其中的Style.Trigger节点,该节点顾名思义可以理解为触发器。在以上代码中表示当鼠标移动到行头上方时,将提示"选中该行"
在对于列头的样式定义中,以上方法是对所有列进行的全局定义。如果你需要将特殊位置的列显示为特殊样式,那么你可以对该列进行单独的样式定义,方法如下:
<DataGridTextColumn Header="编号" Binding="{Binding Path=ID}"> <DataGridColumn.HeaderStyle> <Style TargetType="DataGridColumnHeader"> <Setter Property="Background"> <Setter.Value> <LinearGradientBrush StartPoint="0,0" EndPoint="0,1"> <GradientStop Color="White" Offset="0"/> <GradientStop Color="SkyBlue" Offset="0.5"/> <GradientStop Color="White" Offset="1"/> </LinearGradientBrush> </Setter.Value> </Setter> <Setter Property="Foreground" Value="Black"/> <Setter Property="FontSize" Value="13"/> <Setter Property="Width" Value="100"/> <Style.Triggers> <Trigger Property="IsMouseOver" Value="True"> <Setter Property="ToolTip" Value="按照该列进行排序"/> </Trigger> </Style.Triggers> </Style> </DataGridColumn.HeaderStyle> </DataGridTextColumn>
在该段代码中,DataGridTextColumn代表该列以文本的形式显示,同时显示的数据为您所指定数据源的ID这个字段的数据。在这里我们提到了DataGridTextColumn使其内容按照文本的形式显示,在WPF中提供了四种基本的列显示样式:
DataGridTextColumn 文本显示内容,指定的数据类型为String
DataGridCheckBoxColumn 复选框的形式显示内容,指定的数据类型为Boolean
DataGridComboBoxColumn 下拉列表的形式显示内容,指定的数据类型为Enum
DataGridHyperlinkColumn 超链接的形式显示内容,指定的数据类型为Uri
往往我们在实际的开发中,以上四种样式并不能完全满足我们的需求,此时我们可以利用DataGridTemplateColumn来自定义显示样式,示例如下:
在使用DataGridTemplateColumn时,我们必须先定义DataTemplate:
<Window.Resource> <DataTemplate x:Key="BirthTemplate"> <StackPanel Width="200" Height="20"> <Border Background="Orange" BorderBrush="Black" BorderThickness="1"> <TextBlock Text="{Binding Birthday, StringFormat={}{0:MM-dd}}" FontSize="13" HorizontalAlignment="Center"/> </Border> <Border Background="White" BorderBrush="Black" BorderThickness="1"> <TextBlock Text="{Binding Birthday, StringFormat={}{0:yyyy}}" FontSize="13" HorizontalAlignment="Center"/> </Border> </StackPanel> </DataTemplate> <DataTemplate x:Key="EditingDateTemplate"> <DatePicker SelectedDate="{Binding Birthday}"/> </DataTemplate> </Window.Resource>
使用以上样式:
<DataGridTemplateColumn Header="出生日期" Width="100" CellTemplate="{StaticResource BirthTemplate}" CellEditingTemplate="{StaticResource EditingDateTemplate}"/>
发表评论
-
获取WPF所有控件的模板内容
2013-04-03 15:13 10681. 首先创建XMAL文件 <Windo ... -
委托回调函数的妙用(c# code )
2013-04-03 15:14 1465//person类 public class ... -
DynamicResource与StaticResource的区别
2013-02-20 14:28 0DynamicResource与StaticRes ... -
依赖属性--WPF
2013-02-20 14:27 0/// <summary> / ... -
简单的上传图片
2013-02-20 14:26 0<%@ Page Title="" ... -
C#获取文件夹下所有文件
2013-02-20 14:25 0string fileInfo = string.Empty ... -
如何将input type="file"显示的"浏览" 变成英文的?
2013-02-20 14:25 0解决方法: 方法一:使用英文Windows系统(这 ... -
asp.net mvc 2.0相关的一些内容
2013-02-20 14:24 01.搜索用到ViewTemp[]的时候,要用COOKIE去 ... -
WPF datagrid 弹出右键菜单时先选中该项
2013-02-20 14:23 0privatevoid datagrid_Previ ... -
显示动态的大小写提示框
2013-02-20 14:18 0function detectCapsLock(event) ... -
C# Action<T> 使用
2013-02-20 14:18 0在使用 Action<T> ... -
字符串SubCutString
2013-02-20 14:15 798public static string SubCutStr ... -
正则表达式-关于字符在100以内的字
2013-02-20 14:15 1200^.{0,100} $ 关于字符在100以内的字 ... -
WPF,TextBlock ,ToolTip 显示
2013-02-20 14:14 1220<TextBlock Text="{Bind ... -
后台运行点击事件
2013-02-20 14:13 723button.RaiseEvent(new Route ... -
为你解惑之WPF经典9问详解 .
2013-01-08 15:20 1264第0问:能否简单介绍一 ... -
WPF中TreeView的使用 .
2013-01-08 15:21 2223不管是在窗体程序开发还是在web应用程序开发中,大家都知道树这 ... -
浅谈WPF中x名称空间(二) .
2012-04-13 13:43 1222二、x名称空间中的标记 ... -
浅谈WPF中x名称空间(一) .
2012-04-13 13:22 1137不知道各位同行在创建第一个WPF应用程序时,由编译器自动 ... -
C#正则表达式
2012-04-13 12:41 870(1)“@”符号符下两ows表研究室的火热,当晨在“@”虽然并 ...
相关推荐
标题"WPF.DataGrid.MergeRow"和描述中的"实现功能:WPF下DataGrid实现行单元格合并"正是针对这个需求的解决方案。 DataGrid的行单元格合并功能并不是默认支持的,因此通常需要通过自定义样式、模板和数据绑定来实现...
<DataGrid.Columns> 公司名称" Binding="{Binding CompanyName}" /> <!-- 其他列定义 --> </DataGrid.Columns> </DataGrid> ``` 这里可以添加多种类型的列,如`DataGridTextColumn`、`DataGridCheckBoxColumn`...
1. **WPF Extended.Wpf.Toolkit库的使用** WPF Extended.Wpf.Toolkit库提供了许多额外的控件,如:数字输入框、日历控件、颜色选择器、进度条等,但最引人注意的是它的加载指示器组件。这个库可以通过NuGet包管理器...
<DataGrid.Columns> , UpdateSourceTrigger=PropertyChanged}" /> , UpdateSourceTrigger=PropertyChanged}" /> </DataGrid.Columns> </DataGrid> ``` 4. **使用INotifyPropertyChanged**:为了实现双向绑定,...
在标签中,提到了"C# wpf grid",这暗示了项目使用C#编程语言,这是.NET Framework的主要开发语言,并且与WPF框架紧密集成。此外,"grid"指的是我们讨论的DataGrid控件。 压缩包内的文件名列表如下: 1. MainWindow...
在WPF(Windows Presentation Foundation)开发中,DataGrid控件是一种常用的数据展示工具,它可以用于显示和编辑表格数据。然而,有时我们不仅需要简单的表格布局,还需要层次化的数据展示,也就是树形结构。本项目...
### C# WPF中DataGrid的使用详解 #### 一、引言 DataGrid是WPF框架中的一个重要控件,用于展示数据集。它提供了强大的数据绑定能力,并且支持多种数据操作,如增删改查及分页等功能。本文旨在通过实例详细讲解...
WPF中DataGrid里面的Checkbox实现单选关键代码, 文档里面的代码复制粘贴即可实现!本人也是项目需要写的一个功能11行代码实现此功能! 希望可以帮助到你们!
在WPF(Windows Presentation Foundation)开发中,DataGrid控件是一种常用的数据展示工具,它可以方便地展示表格数据并支持各种交互操作。本话题主要探讨如何在DataGrid中自定义实现最后一行后面添加一个汇总行,这...
10. **在View中使用**:最后,在XAML的View文件中,将ViewModel绑定到DataGrid的`ItemsSource`,并使用`DataTemplate`和`DataGrid.Columns`属性来引用ViewModel中动态生成的列和编辑模板。 通过以上步骤,你就能在...
在Windows Presentation Foundation (WPF) 中,DataGrid控件是一个非常强大的数据展示工具,它可以用于显示和编辑结构化的数据。...希望这个教程对你在实际项目中使用WPF DataGrid展示图片有所帮助。
**在MVVM中使用DataGrid** 1. **数据绑定**:在MVVM中,DataGrid的数据源通常通过ViewModel中的ObservableCollection对象进行绑定。ObservableCollection是.NET Framework提供的一种动态数据集合,当集合中的元素...
在本文中,我们将深入探讨如何在WPF(Windows Presentation Foundation)环境中使用DataGrid控件来操作数据库,实现数据的添加、删除和修改功能。DataGrid是WPF中的一个强大控件,它允许用户以表格的形式展示和编辑...
<DataGrid.Columns> <DataGridTemplateColumn.CellTemplate> , Mode=OneWay}" DisplayMemberPath="OptionName" SelectedValuePath="OptionId" SelectedValue="{Binding Path=SelectedOption, Mode=TwoWay,...
本文将深入探讨如何在`DataGrid`中使用空白行,这对于某些应用场景,如添加新记录或保留用户输入的空间,是很有用的。 `DataGrid`通常与数据绑定,自动根据数据源中的项生成行。然而,为了允许用户插入新的记录或...
在WPF(Windows Presentation Foundation)开发中,`DataGrid`控件是一个常用的数据展示组件,类似于Excel表格。它允许我们以表格形式展示数据,并提供了丰富的功能,如排序、分页、编辑等。当我们需要根据数据的...
6. **使用DataGrid.RowStyle中的DataGridRowHeader**:在某些情况下,可能需要合并表头。这可以通过调整DataGrid.RowStyle中的DataGridRowHeader来实现,但需要注意,WPF DataGrid本身并不直接支持行头的合并,可能...
为了触发行的折叠与展开,你可以使用`DataGrid.RowDetailsVisibilityMode`属性。将其设置为`VisibleWhenSelected`或`Visible`,让用户通过单击行来显示详情,或者设置为`Collapsed`默认隐藏所有详情: ```xml ...
例如,使用`DataGridHeaderBorder`和`DataGridColumnHeader`可以改变列头的样式,`DataGridRow`和`DataGrid.RowStyle`则用于定制行的样式。`DataGridCell`则可以定制单元格的样式,包括选中和编辑状态。 3. **数据...
foreach (DataGridColumn column in dataGrid.Columns) { // 遍历列并计算总和 double sum = 0; foreach (var item in dataGrid.Items) { sum += (double)column.GetCellContent(item).DataContext; } // ...