WPF之DataGrid用法(一)

介绍数据表格DataGrid的基础用法。

DataGrid可用AutoGenerateColumns属性控制列的生成。Column包含DataGridTextColumn、DataGridCheckBoxColumn、DataGridComboBoxColumn、DataGridHyperlinkColumn、DataGridTemplateColumn等5中格式。


1.DataGridTextColumn

DataGridTextColumn最常用,不再做介绍。

2.DataGridCheckBoxColumn

DataGridCheckBoxColumn是勾选框数据列。效果如下:

主要XAML代码:
<DataGridCheckBoxColumn Binding="{Binding Selected,NotifyOnSourceUpdated=True,UpdateSourceTrigger=PropertyChanged}" 
						HeaderStyle="{StaticResource DataGridColumnHeaderStyle1}">
	<DataGridCheckBoxColumn.Header>
		<CheckBox IsChecked="{Binding IsAllSelected,RelativeSource={RelativeSource AncestorType={x:Type local:DataGridCheckBoxColumn}}}"/>
	</DataGridCheckBoxColumn.Header>
</DataGridCheckBoxColumn>
其中列头选择框居中需要修改HeaderStyle属性,修改ContentPresenter的HorizontalAlignment="Center"即可。修改样式通常使用Blend完成,这里就不在详细介绍。
另外,通过设置NotifyOnSourceUpdated=True,当数据选择框选择更改时来触发消息,而后用DataGrid的SourceUpdated事件来捕获,在事件中处理列头选择框的状态。

3.DataGridComboBoxColumn

若要填充下拉列表,请首先使用下列选项之一设置 ComboBox 的 ItemsSource 属性。
  • 静态资源。 
  • x:Static 代码实体。
  • ComboBoxItem 类型的内联集合。
实现效果如下:

如需使用非静态资源,则需要使用DataGridComboBoxColumn的EditingElementStyle样式修改编辑样式,通过ElementStyle修改正常显示(非编辑状态)样式。
主要XAML代码如下:
<DataGrid x:Name="grd" ItemsSource="{Binding StuList3}" AutoGenerateColumns="False">
	<DataGrid.Columns>
		<DataGridTextColumn Binding="{Binding No}" Header="学号"/>
		<DataGridTextColumn Binding="{Binding Name}" Header="姓名"/>
		<!--使用普通List集合-->
		<DataGridComboBoxColumn x:Name="cmb" Header="性别">
			<DataGridComboBoxColumn.EditingElementStyle>
				<Style TargetType="ComboBox">
					<Setter Property="ItemsSource" Value="{Binding Path=DataContext.SexList,ElementName=grd}" />
					<Setter Property="DisplayMemberPath" Value="Name" />
					<Setter Property="SelectedValuePath" Value="Name" />
					<Setter Property="SelectedValue" Value="{Binding Sex,UpdateSourceTrigger=PropertyChanged}" />
				</Style>
			</DataGridComboBoxColumn.EditingElementStyle>
			<DataGridComboBoxColumn.ElementStyle>
				<Style TargetType="ComboBox">
					<Setter Property="ItemsSource" Value="{Binding Path=DataContext.SexList,ElementName=grd}" />
					<Setter Property="DisplayMemberPath" Value="Name" />
					<Setter Property="SelectedValuePath" Value="Name" />
					<Setter Property="SelectedValue" Value="{Binding Sex}" />
				</Style>
			</DataGridComboBoxColumn.ElementStyle>
		</DataGridComboBoxColumn>
		<!--使用静态资源-->
		<DataGridComboBoxColumn Header="性别(静态资源)" ItemsSource="{Binding Source={StaticResource myEnum}}"
								TextBinding="{Binding Sex}"
								SelectedItemBinding="{Binding Sex,UpdateSourceTrigger=PropertyChanged}">
		</DataGridComboBoxColumn>
		<!--使用x:Static扩展标记-->
		<DataGridComboBoxColumn Header="性别(x:Static)" ItemsSource="{x:Static local:ViewModel.SexList2}"
								TextBinding="{Binding Sex}"
								SelectedItemBinding="{Binding Sex,UpdateSourceTrigger=PropertyChanged}">
		</DataGridComboBoxColumn>
		<!--使用内联集合-->
		<DataGridComboBoxColumn Header="性别(内联集合)"
								TextBinding="{Binding Sex}"
								SelectedItemBinding="{Binding Sex,UpdateSourceTrigger=PropertyChanged}">
			<DataGridComboBoxColumn.ItemsSource>
				<col:ArrayList>
					<sys:String>男</sys:String>
					<sys:String>女</sys:String>
				</col:ArrayList>                       
			</DataGridComboBoxColumn.ItemsSource>
		</DataGridComboBoxColumn>
	</DataGrid.Columns>
</DataGrid>


4.DataGridHyperlinkColumn

使用 DataGridHyperlinkColumn 来显示包含 Uri 的数据,如 HTTP 地址或电子邮件地址。只有在 Hyperlink 的直接或间接父级是导航主机时,才会发生 Hyperlink 导航。 导航主机的例子包括 NavigationWindow、 Frame、或任何可以承载 XBAPs(如 Microsoft Internet Explorer 6 或更高版本以及 Firefox 2.0 或更高版本)的浏览器。
实现效果如下:

主要XAML代码:
<DataGridHyperlinkColumn Binding="{Binding Http}" ContentBinding="{Binding Name}" Header="网址"/>

5.DataGridTemplateColumn

借助于 DataGridTemplateColumn 类型,可以通过指定用于显示和编辑值的单元格模板来创建您自己的列类型。
DataGridTemplateColumn可实现以上任何功能,包括checkbox,combobox等。
现实现如下效果:

通过修改显示模板和编辑模板来实现功能,主要XMAL代码如下:
<!--显示模板-->
<DataTemplate x:Key="DateTemplate" >
	<StackPanel Width="60" Height="30">
		<Border Background="LightBlue" BorderBrush="Black" BorderThickness="1,1,1,0">
			<TextBlock Text="{Binding Birth, StringFormat={}{0:MMM d}}" FontSize="10" HorizontalAlignment="Center" />
		</Border>
		<Border Background="White" BorderBrush="Black" BorderThickness="1">
			<TextBlock Text="{Binding Birth, StringFormat={}{0:yyyy}}" FontSize="10" FontWeight="Bold" HorizontalAlignment="Center" />
		</Border>
	</StackPanel>
</DataTemplate>
<!--编辑模板-->
<DataTemplate x:Key="EditingDateTemplate">
	<DatePicker SelectedDate="{Binding Birth}"  />
</DataTemplate>




作者:FoolRabbit
出处:http://blog.csdn.net/rabbitsoft_1987
欢迎任何形式的转载,未经作者同意,请保留此段声明!

  • 10
    点赞
  • 63
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

FoolRabbit

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值