WPF中的数据模板使用方式之一:CONTENTCONTROL、CONTENTTEMPLATE和TEMPLATESELECTOR的使用
在WPF中,数据模板是非常强大的工具,他是一块定义如何显示绑定的对象的XAML标记。有两种类型的控件支持数据模板:(1)内容控件通过ContentTemplate属性支持数据模板;(2)列表控件通过ItemTemplate属性支持数据模板。为了能够进一步提升数据模板的功能,在使用中常常会要求动态选择数据模板。对于列表控件,可以通过设置DataType来解决,复杂时需要使用模板选择器。以下主要谈论以下内容控件中的模板选择。
在WPF中,有时内容控件(如ContentControl,Button等)会根据数据对象的类型而需要动态变换,可以使用数据模板配合模板选择器来解决。模板选择器需要从System.Windows.Controls.DataTemplateSelector继承,重写其SelectTemplate方法,在该方法中根据item的类型或item属性来选择合适的数据模板。为了能够选择模板,需要将模板定义为属性,如public DataTemplate BoxGirderTemplate { get; set; }等等。
public class MyContentTemplateSelector:DataTemplateSelector
{
public DataTemplate BoxTemplate { get; set; }
public DataTemplate SlabTemplate { get; set; }
public DataTemplate TGirderTemplate { get; set; }
public override DataTemplate SelectTemplate(object item, DependencyObject container)
{
ISec s = (ISec)item;
if (s!=null&&s.Name == "Box")
return BoxGirderTemplate;
else if (s != null && s.Name == "Slab")
return SlabTemplate;
else if (s != null && s.Name == "TGirder")
return TGirderTemplate;
return null;
}
}
在xaml中,在内容控件中实例化模板选择器。在实例化模板选择器的过程中,将数据模板作为模板选择器的参数注入,代码如下:
<ContentControl Name="MyContentControl">
<ContentControl.ContentTemplateSelector>
<local:ElementPropContentTemplateSelector BoxTemplate="{StaticResource BoxGirder}" SlabTemplate="{StaticResource Slab}" TGirderTemplate="{StaticResource TGirder}"/>
</ContentControl.ContentTemplateSelector>
</ContentControl>
此外,在Windows.Resources中,需要定义数据模板,代码如下:
<Window.Resources>
<DataTemplate x:Key="BoxGirder">
<StackPanel >
..........................
</StackPanel>
</DataTemplate>
<DataTemplate x:Key="Slab">
<StackPanel >
..........................
</StackPanel>
</DataTemplate>
<DataTemplate x:Key="TGirder">
<StackPanel >
..........................
</StackPanel>
</DataTemplate>
<Window.Resources>
原文地址:https://www.cnblogs.com/bruce1992/p/15024213.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Keras自动下载的数据集/模型存放位置介绍
- Keras 切换后端方式(Theano和TensorFlow)
- python 字符串的驻留机制及优缺点
- php微信公众号开发之翻页查询
- php 中phar包的使用教程详解
- php微信公众号开发之快递查询
- Scrapy框架介绍之Puppeteer渲染的使用
- Keras设置以及获取权重的实现
- Java自动化测试(Android app界面元素 33)
- 太厉害了,这款开源类库可以帮你简化每一行代码
- Linux ps和pstree命令知识点总结
- CentOS7上以rpm方式安装JDK8
- linux DMA接口知识点详解
- Linux中使用crond工具创建定时任务的方法
- Linux which命令的具体使用