博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
继续聊WPF——动态数据模板
阅读量:6256 次
发布时间:2019-06-22

本文共 2270 字,大约阅读时间需要 7 分钟。

 

 我为啥称之为“动态数据模板”?先看看下面的截图,今天,我们就是要实现这种功能。

 

大概是这样的,我们定义的DataTemplate是通过触发器动态应用到 ComboBoxItem 上。

这个下拉列表控件绑定了一个Person集合,Person类的定义如下:

 

public class Person { public string Name { get; set; } public int Age { get; set; } public string Email { get; set; } public override string ToString() { return Name; } }

 

这里重写了ToString方法,因为ComboBox生成的项是调用对象的ToString方法的,为了能不设置数据模板的前提下正确显示列表项,需要重写ToString方法,默认显示姓名属性。
 
然后,我们为ComboBoxItem定义一个处于高亮状态时使用的数据模板,也就是当鼠标移到项上时发生。
<Window.Resources> <!-- 当项高亮显示时使用的数据模板 --> <DataTemplate x:Key="hightlightTmp"> <Grid> <Grid.RowDefinitions> <RowDefinition Height="auto"/> <RowDefinition Height="auto"/> </Grid.RowDefinitions> <StackPanel Margin="0,5,0,0" Grid.Row="0" Orientation="Horizontal"> <TextBlock Margin="2,0" FontWeight="Bold" FontSize="14"> <TextBlock.Text> <Binding Path="Name" StringFormat="姓名:{0}"/> </TextBlock.Text> </TextBlock> <TextBlock Margin="20,0"> <TextBlock.Text> <Binding Path="Age" StringFormat="年龄:{0}"/> </TextBlock.Text> </TextBlock> </StackPanel> <TextBlock Margin="0,2,0,5" Grid.Row="1"> <TextBlock.Text> <Binding Path="Email" StringFormat="电邮:{0}"/> </TextBlock.Text> </TextBlock> </Grid> </DataTemplate> .............. </Window.Resources>

 

为 ComboBoxItem 定义一个样式。
<Window.Resources> ................ <!-- 项样式 --> <Style x:Key="cmbStyle" TargetType="{x:Type ComboBoxItem}"> <Style.Triggers> <Trigger Property="IsHighlighted" Value="True"> <Setter Property="ContentTemplate" Value="{StaticResource hightlightTmp}"/> </Trigger> </Style.Triggers> </Style> </Window.Resources>

 

在窗体中声明一个ComboBox。
<Grid> <ComboBox x:Name="cmb" Margin="10,10" Height="24" Width="200" HorizontalAlignment="Left" VerticalAlignment="Top" ItemContainerStyle="{StaticResource cmbStyle}"/> </Grid>

 

最后,切换到代码视图,完成设置数据源的C#代码。
public Window1() { InitializeComponent(); this.cmb.ItemsSource = new Person[] { new Person{Name="小李",Age=22,Email="suk211@163.com"}, new Person{Name="小王",Age=20,Email="minat@126.com"}, new Person{Name="黄涨",Age=21,Email="laned2@21cn.com"}, new Person{Name="高产",Age=22,Email="ha@136.com"}, new Person{Name="杜林",Age=21,Email="null@yaahoo.com"}, new Person{Name="杨白姥",Age=50,Email="cYang@21cn.com"}, new Person{Name="鸟人",Age=31,Email="bgl@ask.net.cn"}, new Person{Name="宋小八",Age=28,Email="xde227@123h.com"} }; }

 

完成,这时候运行一下,你会看到上文中截图中的效果了。

转载地址:http://mfnsa.baihongyu.com/

你可能感兴趣的文章
Linux 用户管理
查看>>
linux 终端颜色代码
查看>>
oracle的drop命令
查看>>
用R语言和java实现随机生成手机号码
查看>>
Oracle DG 之-- Remove DG Broker
查看>>
5.2 let it snow--game programming gems 5 笔记
查看>>
解决error: Failed dependencies:libodbc.so.2()的错误
查看>>
SCOM 2012系列⑤邮件通知上
查看>>
ionic3 引入jquery
查看>>
Unable to connect to the MKS: Internal error after cloning
查看>>
How to check server memory model for extend the physical memory
查看>>
Running nested VM on vSphere 5
查看>>
JsonSerializable
查看>>
commons-dbcp 1.4需要JDK 1.6
查看>>
简单lnmp搭建及nginx反代模型的实现
查看>>
设计与梳理企业二级流程的路线方法
查看>>
我的友情链接
查看>>
一个节奏极快的创业公司的web前端持续交付心路历程
查看>>
windows隐藏python运行时的终端
查看>>
QT以QImag显示图片并且以固定大小放缩后显示
查看>>