XAML属性介绍
开发工具与关键技术: VS XAML元素
作者:刘铭聪
撰写时间:2021年8月19日
XAML属性介绍
一、属性设置几种方式
属性:
属性是对XAML元素特征进行描述的方法;属性不允许在XAML中重复设置多次;允许
在托管代码中改变元素的属性值
设置几种方式:
使用特性语法(属性语法)
使用属性元素语法
使用内容元素语法
使用集合语法
1、使用特性语法(属性语法)
对象的属性通常可表示为对象元素的特性。 特性语法对设置的对象属性命名,后跟赋值
运算符 (=)。 特性的值始终指定为包含在引号中的字符串。
特性语法是最简化的属性设置语法,并且对曾使用过标记语言的开发人员而言是最直观
的语法。
每个属性对应一个属性值,属性值类型必须与属性匹配
一个标记中可以设置对象的多个属性
只有实例化对象才可以设置实例属性,格式如下:
例子:
例子效果:
2、使用属性元素语法
对于对象元素的某些属性,无法使用特性语法,因为无法在特性语法的引号和字符串限
制内充分地表达提供属性值所必需的对象或信息。 对于这些情况,可以使用另一个语
法,即属性元素语法。
属性元素开始标记的语法为 <TypeName.PropertyName>。 通常,该标记的内容是类型
的对象元素,属性会将该元素作为其值。 指定内容之后,必须用结束标记结束属性元
素。 结束标记的语法为 </TypeName.PropertyName>。
某些属性可以使用属性元素语法来设置,格式为
例子:
例子效果:
3、使用内容元素语法
某些元素的属性支持内容元素语法,允许忽略元素的名称
实力对象会根据XAML元素中的第一个标记值来设置属性
对于大量的格式化文本,使用内容元素语法更加灵活
属性标记之间可以插入大量的文本内容
例子:
XAML 内容属性值必须是连续的
XAML 内容属性的值必须完全在该对象元素上的任何其他属性元素之前或之后指定。 无论 XAML 内容属性的值是指定为字符串,还是指定为一个或多个对象,都是如此。 例如,以下标记不会进行分析:
这对于本质而言是非法的,因为如果通过使用 content 属性的属性元素语法使此语法变为显式,则内容属性将设置两次:
例如,如果 content 属性是一个集合,并且子元素与属性元素交错在一起,则这是一个类似的非法示例:
4、使用集合语法
XAML规范要求XAML处理器实现来标识值类型为集合的属性。 .NET 中的常规 XAML 处理器实现基于托管代码和 CLR,并通过以下方法之一标识集合类型:
类型实现 IList 。
类型实现 IDictionary 。
类型派生自 Array (有关 XAML 中数组的详细信息,请参阅 X:Array 标记扩展。 )
XAML 语言包含一些优化,可以生成更易于阅读的标记。 其中一项优化是:如果某个特定属性采用集合类型,则在标记中声明为该属性的值内的子元素的项将成为集合的一部分。 在这种情况下,子对象元素的集合是设置为集合属性的值。
元素支持一个属性元素的集合,才使用集合语法进行设置属性
使用托管代码的Add方法来增加更多的集合元素
本质是向对象的集合中添加属性项
例子:
例子效果:
二、基本属性、附加属性和依赖属性
1、附加属性
附加属性作用于支持附加属性的元素
附加属性是由支持附加属性的父元素产生作用,支持附加属性的元素会继承所在的父元素的属性
附加属性的格式:AttachedPropertyProvider.PropertyName
例子:
例子效果:
2、依赖属性
英文名称:Dependency Properties
依赖属性和CRL属性类似,提供一个实例级私有字段的访问封装,通过GetValue和 SetValue访问器实现属性的读写操作
最重要一个特点是属性值依赖于一个或者多个数据源,提供这些数据源的方式也可 以不同
由于依赖多数据源的缘故,故称之为依赖属性
一、什么是依赖属性
依赖属性就是一种自己可以没有值,并且可以通过Binding绑定从其他数据源获取值。依赖属性可支持WPF中的样式设置、数据绑定、继承、动画及默认值。
属性的场景:
- 希望可在样式中设置属性。
- 希望属性支持数据绑定。
- 希望可使用动态资源引用设置属性。
- 希望从元素树中的父元素自动继承属性值。
- 希望属性可进行动画处理。
- 希望属性系统在属性系统、环境或用户执行的操作或者读取并使用样式更改了属性以前的值时报告。
- 希望使用已建立的、WPF 进程也使用的元数据约定,例如报告更改属性值时是否要求布局系统重新编写元素的可视化对象。
二、依赖属性的特点
无论什么时候,只要依赖属性的值发生改变,wpf就会自动根据属性的元数据触发一系列的动作,这些动作可以重新呈现UI元素,也可以更新当前的布局,刷新数据绑定等等,这种变更的通知最有趣的特点之一就是属性触发器,它可以在属性值改变的时候,执行一系列自定义的动作,而不需要更改任何其他的代码来实现。通过下面的示例来演示属性变更通知
示例:当鼠标移动到Button按钮上面时,文字的前景色变为红色,离开时变为默认颜色黑色,采用传统方式和依赖属性两种方式实现:
使用传统方式实现:XAML代码
C#后台代码实现:
(2)使用依赖属性实现,XAML界面代码:
使用上面的两种方式都可以实现Button按钮的前景色改变,效果如下:
示例:XAML代码
例子效果