继续聊WPF——动态数据模板

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

 

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

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

 

[csharp] view plain copy
  1. public class Person  
  2. {  
  3.     public string Name { get; set; }  
  4.     public int Age { get; set; }  
  5.     public string Email { get; set; }  
  6.     public override string ToString()  
  7.     {  
  8.         return Name;  
  9.     }  
  10. }  


 

这里重写了ToString方法,因为ComboBox生成的项是调用对象的ToString方法的,为了能不设置数据模板的前提下正确显示列表项,需要重写ToString方法,默认显示姓名属性。
然后,我们为ComboBoxItem定义一个处于高亮状态时使用的数据模板,也就是当鼠标移到项上时发生。
[html] view plain copy
  1. <Window.Resources>  
  2.     <!-- 
  3.         当项高亮显示时使用的数据模板 
  4.     -->  
  5.     <DataTemplate x:Key="hightlightTmp">  
  6.         <Grid>  
  7.             <Grid.RowDefinitions>  
  8.                 <RowDefinition Height="auto"/>  
  9.                 <RowDefinition Height="auto"/>  
  10.             </Grid.RowDefinitions>  
  11.             <StackPanel Margin="0,5,0,0" Grid.Row="0" Orientation="Horizontal">  
  12.                 <TextBlock Margin="2,0" FontWeight="Bold" FontSize="14">  
  13.                             <TextBlock.Text>  
  14.                                 <Binding Path="Name"  
  15.                                          StringFormat="姓名:{0}"/>  
  16.                             </TextBlock.Text>  
  17.                 </TextBlock>  
  18.                 <TextBlock Margin="20,0">  
  19.                             <TextBlock.Text>  
  20.                                 <Binding Path="Age"  
  21.                                          StringFormat="年龄:{0}"/>  
  22.                             </TextBlock.Text>  
  23.                 </TextBlock>  
  24.             </StackPanel>  
  25.             <TextBlock Margin="0,2,0,5" Grid.Row="1">  
  26.                         <TextBlock.Text>  
  27.                             <Binding Path="Email"  
  28.                                      StringFormat="电邮:{0}"/>  
  29.                         </TextBlock.Text>  
  30.             </TextBlock>  
  31.         </Grid>  
  32.     </DataTemplate>  
  33.        ..............          
  34. </Window.Resources>  


 

为 ComboBoxItem 定义一个样式。
[html] view plain copy
  1. <Window.Resources>  
  2.      ................          
  3.     <!-- 项样式 -->  
  4.     <Style x:Key="cmbStyle" TargetType="{x:Type ComboBoxItem}">  
  5.         <Style.Triggers>  
  6.             <Trigger Property="IsHighlighted" Value="True">  
  7.                 <Setter Property="ContentTemplate"  
  8.                         Value="{StaticResource hightlightTmp}"/>  
  9.             </Trigger>  
  10.         </Style.Triggers>  
  11.     </Style>  
  12. </Window.Resources>  


 

在窗体中声明一个ComboBox。
[html] view plain copy
  1. <Grid>  
  2.     <ComboBox x:Name="cmb" Margin="10,10"  
  3.               Height="24" Width="200"  
  4.               HorizontalAlignment="Left"  
  5.               VerticalAlignment="Top"  
  6.               ItemContainerStyle="{StaticResource cmbStyle}"/>  
  7. </Grid>  


 

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


 

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

转载于:https://www.cnblogs.com/sjqq/p/8379479.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/267658.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

刺激战场c语言,刺激战场:假车库、C字楼都是啥?学会吃鸡术语新手变大神!...

原标题&#xff1a;刺激战场&#xff1a;假车库、C字楼都是啥&#xff1f;学会吃鸡术语新手变大神&#xff01;刺激战场有越来越多的新玩家加入其中&#xff0c;然而新手想入门&#xff0c;却有时候找不对方法&#xff0c;其实吃鸡这个游戏其实还是非常简单的&#xff0c;不过想…

HTMLParser-实战

了解了HTMLParser库的知识后&#xff0c;选择做一个小训练&#xff0c;对https://www.python.org/events/python-events/这个网址进行分析&#xff0c;之后输出其中每次会议的题目、时间和地点。 如果要简单了解下HTMLParser库可以点击打开 下面进入正题 这是网站的源码&#x…

c++2015语言,2015年7月TIOBE编程语言排行榜:C++ 的复兴

2015年7月TIOBE编程语言排行榜&#xff1a;C 的复兴C是2015年上半年同比增长最快的编程语言。具体为C 增长3.1%&#xff0c;Java 增长2.0%&#xff0c;C#增长1.6%&#xff0c;Python增长1.6%。C大幅度增长的原因可能是引入了新的C11标准。这使得C被大范围的接受。C 11标准为C带…

android抽奖动画,Android App中实现简单的刮刮卡抽奖效果的实例详解

主要思想&#xff1a;将一个view设计成多层&#xff1a;背景层&#xff0c;含中奖信息等&#xff1b;遮盖层&#xff0c;用于刮奖&#xff0c;使用关联一个Bitmap的Canvas在该Bitmap上&#xff0c;使用它的canvas.drawPath的api来处理 手势滑动(类似刮奖的动作)使用paint.setXf…

如何提高英语听力(内容摘自NECCS)+ 乘法表

乘法表 print(\n.join([ .join([%s*%s%-2s%(y,x,x*y) for y in range(1,x1)]) for x in range(1,10)])) 如何提高英语听力 很喜欢这篇关于提高英语听力的文章&#xff0c;所以收藏下来和大家一同分享一下 人走路时要用两条腿&#xff0c;没有任何人会觉得走路费劲。可如果让人…

android新拟态实现方法,Android 新拟态UI (Neumorphism)

前言本文转自github&#xff0c;只是进行了图片的处理和部分翻译&#xff0c;已获作者授权截至首次发文前找到的原作者的文章地址-May,17,2020若找到本文章更新的时间节点&#xff0c;请私信我更新。原作者github地址文末附源码下载地址&#xff0c;免费。Android上的拟态化UIT…

codeforces 919E Congruence Equation

E. Congruence Equationtime limit per test3 secondsmemory limit per test256 megabytesinputstandard inputoutputstandard outputGiven an integer x. Your task is to find out how many positive integers n (1 ≤ n ≤ x) satisfy where a, b, p are all known co…

android 过滤数组中的重复元素,Flutter List数组避免插入重复数据的实现

List具有一定长度存在索引的对象集合(长度为0不存在索引,长度>0存在索引)常见列表1、定长列表默认值null例如:List fixedLengthList new List(2)、List fixedLengthList new List(8)List fixedLengthList new List(2);for(int i0;i<2;i){print("索引为${i}的值${…

[js]jquery里的jsonp实现ajax异源请求

同源请求-jquery <script type"text/javascript" src"http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script><script type"text/javascript">$.ajax({url: "data.txt",type: "get",dataType…

android listview remove 动画,给Android ListView添加删除item动画

给Android ListView添加删除item动画给listview删除一个item的时候加上一个折叠动画&#xff0c;感觉效果会好一点。步骤是当删除一个view&#xff0c;先用动画把view的高度改变&#xff0c;看上去就是折叠的效果。当动画完成的时候&#xff0c;再真正把item移除。private void…

Css 选择器 算法 规则

首先上图 css 命令在读取时是按照其优先级的高低的先后顺序来解读的&#xff0c;当优先级相同时是按照其css命令写的先后顺序来读取的&#xff0c;即后面的css覆盖&#xff08;前后css属性设置 不同时&#xff09;或继承&#xff08;前后css属性设置相同或后面未设置该css属性时…

Python算法——二叉树

一、二叉树 from collections import dequeclass BiTreeNode:def __init__(self, data):self.data dataself.lchild Noneself.rchild Nonea BiTreeNode(A) b BiTreeNode(B) c BiTreeNode(C) d BiTreeNode(D) e BiTreeNode(E) f BiTreeNode(F) g BiTreeNode(G)e.lchil…

艾伟_转载:.NET 4.0新特性-- Corrupted State Exceptions

作为程序员&#xff0c;我想很多人应该都有过跟异常打交道的经历。而且相信也有很多人也都写过catch(Exception e){//blabla}这种把所有未知异常一股脑儿捕获并处理掉的代码吧。不管是为敷衍客户也好&#xff0c;让程序继续运行以避免糟糕的用户体验也罢&#xff0c;在微软眼中…

艾伟_转载:使用Lambda表达式编写递归函数

前言 著名的牛顿同学曾经说过&#xff1a;如果说我比别人看得更远些,那是因为我站在了巨人的肩上. 原文&#xff1a;If I have been able to see further, it was only because I stood on the shoulders of giants. Whats Lambda表达式? 请参考msdn&#xff1a;Lambda 表达式…

腾讯测试鸿蒙系统,爆料:荣耀 30 Pro已开始测试华为鸿蒙系统

某数码博主今日放出了一张华为内部关于荣耀 30 Pro 测试 HarmonyOS 的截图&#xff0c;图片显示该机正运行基于 HarmonyOS 2.0 开发者测试版的系统。此外&#xff0c;他还透露荣耀 30 系列、V30 系列、Play4 Pro 下个月将升级到华为鸿蒙系统。华为在 2019 年开发者大会上正式推…

html多行文本框下拉,html基础-表单控件、密码框、单选按钮、复选框、多行文本框、下拉列表、按钮(提交、图片、重置)...

表单的介绍(将前端页面表单的值发送给后台&#xff0c;后台通过表单中name属性取值)可以获取客户端的信息(数据)&#xff0c;表单有各种各样的控件&#xff0c;输入框&#xff0c;复选框 按钮等表单的功能&#xff1a;交互功能表单的工作原理&#xff1a;浏览有表单的页面&…

Lync Server 2010的部署系列_第七章 部署边缘服务器(上)

一、配置边缘支持的内部DNS记录 1) 登录DC.Gianthard.com&#xff08;192.168.1.11&#xff09;。在相应的 DNS 服务器上&#xff0c;依次单击“开始”、“控制面板”、“管理工具”&#xff0c;然后单击“DNS”。 2) 在 SIP 域的控制台树中&#xff0c;展开“正向查找区域”&a…

html5 txt文件上传,JavaScript html5利用FileReader实现上传功能

本文实例为大家分享了H5利用FileReader上传文件的具体代码&#xff0c;供大家参考&#xff0c;具体内容如下1. Html部分文件上传演练Browse...2. JS部分var result document.getElementById("result");var input document.getElementById("file_input");…

一起谈.NET技术,ASP.NET 请求处理流程

HTTP处理流程图 以上流程的一些概念解释&#xff1a; 1.http.sys 是一个位于Win2003和WinXP SP2中的操作系统核心组件&#xff0c;能够让任何应用程序通过它提供的接口&#xff0c;以http协议进行信息通讯。 温馨提示&#xff1a;如果用户不慎删除了该驱动文件&#xff0c;不用…

链接在HTML的英文,英文:A链接标记ie下会自动补全href_HTML/Xhtml_网页制作

英文:A链接标记ie下会自动补全href.Whilst working on the Ajax Link Tracker and MapSurface I have come across an inconsistency in how the href attribute is retrieved using DOM Scripting.The href attribute is different to other element attributes in that the v…